Arthas 线上常用命令速查手册:Java 诊断神器,5 分钟定位线上问题!

429 阅读3分钟

1763883473870.png

一、Arthas 是什么?为什么用它?

Arthas 是阿里巴巴开源的一款 Java 线上诊断工具,无需重启 JVM、无需修改代码,即可实时监控、诊断 Java 应用的运行状态。

✅ 适用场景

场景传统方式Arthas 方式
线上 CPU 飙高top + jstack 手动抓栈thread -n 3 一键定位
接口响应慢加日志 → 重新发布trace 追踪耗时
代码未生效怀疑人生jad 反编译确认
异常信息不全日志缺失watch 实时观测
热更新重启服务redefine 热加载

二、快速安装与启动

1. 一键启动(推荐)

curl -O https://arthas.aliyun.com/arthas-boot.jar
java -jar arthas-boot.jar

2. 选择目标进程

[INFO] Found existing java process, please choose one:
* [1]: 12345 demo.jar
  [2]: 67890 app.jar

输入编号(如 1)即可 attach。


三、线上高频命令速查表

命令功能示例
dashboard实时系统面板(线程、内存、GC)dashboard -i 2000 -n 5
thread线程分析thread -n 3(最忙线程)
thread -b(死锁)
trace方法耗时追踪trace com.example.UserService getUserById
watch观测方法入参/返回值/异常watch com.example.UserService getUserById "{params, returnObj, throwExp}" -x 3
jad反编译类或方法jad com.example.UserService
sc查找已加载的类sc -d com.example.UserService
sm查看类方法签名sm -d com.example.UserService
monitor方法调用统计monitor -c 60 com.example.UserService getUserById
tt方法调用时光隧道(记录与回放)tt -t com.example.UserService getUserById
heapdump导出堆快照heapdump /tmp/dump.hprof
profiler生成 CPU 火焰图profiler startprofiler stop --format html
redefine热更新 .class 文件redefine /tmp/UserService.class

四、实战案例:5 分钟定位线上问题

案例 1:CPU 飙高

# 1. 查看最忙线程
thread -n 1

# 2. 查看堆栈
thread 123

# 3. 反编译问题方法
jad com.example.MyService calculate

案例 2:接口响应慢

# 1. 追踪方法耗时
trace com.example.controller.UserController getProfile

# 2. 发现数据库查询慢
trace com.example.dao.UserDAO findById

# 3. 查看 SQL 参数
watch com.example.dao.UserDAO findById "{params[0]}" -x 1

案例 3:代码未生效(热更新)

# 1. 反编译源码
jad com.example.UserService --source-only > /tmp/UserService.java

# 2. 修改代码后编译
mc /tmp/UserService.java -d /tmp

# 3. 热加载
redefine /tmp/com/example/UserService.class

五、注意事项与最佳实践

项目建议
权限控制生产环境限制使用权限,避免误操作
性能影响watchtrace 会增强字节码,排查后及时 stopreset
安全风险禁止将 Arthas 暴露在公网,建议通过隧道或跳板机访问
命令冲突redefinewatch/trace 冲突,使用前需 reset

六、进阶:Docker & K8s 集成建议

Dockerfile 示例(预装 Arthas)

FROM openjdk:8-jdk-alpine
COPY arthas /opt/arthas
COPY app.jar /app.jar
CMD java -jar /app.jar & \
    sleep 15 && \
    java -jar /opt/arthas/arthas-boot.jar --tunnel-server 'ws://tunnel-server:7777/ws' --app-name myapp

K8s 一键 attach(推荐)

helm install arthas arthas/arthas-k8s
arthas-k8s attach myapp-0

七、总结:一张图记住 Arthas

+--------------------------------------------------+
|                    Arthas                        |
|                                                  |
|  dashboard → 系统面板                            |
|  thread   → 线程/死锁                            |
|  trace    → 方法耗时                             |
|  watch    → 入参/返回值/异常                      |
|  jad      → 反编译                               |
|  tt       → 时光隧道(记录+回放)                 |
|  redefine → 热更新                               |
|  profiler → 火焰图                               |
+--------------------------------------------------+

八、参考资料与延伸阅读


© 2025 技术博客 | 转载请注明原作者与链接