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

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

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

✅ 适用场景

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

二、快速安装与启动

1. 一键启动(推荐)

bash 复制代码
curl -O https://arthas.aliyun.com/arthas-boot.jar
java -jar arthas-boot.jar

2. 选择目标进程

bash 复制代码
[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 飙高

bash 复制代码
# 1. 查看最忙线程
thread -n 1

# 2. 查看堆栈
thread 123

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

案例 2:接口响应慢

bash 复制代码
# 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:代码未生效(热更新)

bash 复制代码
# 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)

dockerfile 复制代码
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(推荐)

bash 复制代码
helm install arthas arthas/arthas-k8s
arthas-k8s attach myapp-0

七、总结:一张图记住 Arthas

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

八、参考资料与延伸阅读


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

相关推荐
不能放弃治疗2 小时前
单 Agent 实现模式
后端
IT_陈寒4 小时前
Redis内存爆了,原来我漏掉了这个致命配置
前端·人工智能·后端
fliter5 小时前
最后一块拼图:用 bitvec 构造 IPv4 包,真正做出自己的 Ping
后端
fliter6 小时前
用 Rust 解析并生成 ICMP 包:checksum、nom 与 cookie-factory
后端
蝎子莱莱爱打怪6 小时前
XZLL-IM干货系列 03|消息 ID 设计:一个 UUID 搞不定的事,我用两个 ID 解决了
后端·面试·开源
fliter6 小时前
从 panic 到 Result:用 Rust 重新整理一个 ping 项目的错误处理
后端
森蓝情丶7 小时前
我给 AI 搭了个法庭:一个前端仔的 LangGraph 实战全记录
前端·后端
JensCS猿7 小时前
从 Spring Boot 回看 SSM 框架:手动挡与自动挡的驾驶哲学
后端
爱勇宝7 小时前
干了近 8 年,一夜之间被裁:AI 时代,程序员最该害怕的不是 AI
前端·后端·程序员
科米米7 小时前
嵌入式日志模块
后端