arthas使用场景
Arthas是阿里巴巴开源Java诊断工具,当你遇到以下类似问题而束手无策时,Arthas可以帮助你解决:
- 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception?
- 我改的代码为什么没有执行到?难道是我没 commit?分支搞错了?
- 遇到问题无法在线上 debug,难道只能通过加日志再重新发布吗?
- 线上遇到某个用户的数据处理有问题,但线上同样无法 debug,线下无法重现!
- 是否有一个全局视角来查看系统的运行状况?
- 有什么办法可以监控到JVM的实时运行状态?
- 怎么快速定位应用的热点,生成火焰图?
开始使用
下载arthas-boot.jar,然后用java -jar的方式启动(推荐方式):
curl -O https://arthas.aliyun.com/arthas-boot.jar
java -jar arthas-boot.jar
常见问题
1. 启动找不到进程号?
- 确认存在java进程
ps -ef|grep java
- 确认环境,jre和openjdk不支持jps命令,没法获取pid
安装oracle jdk或者通过ps -ef|grep java获取pid,然后运行java -jar arthas-boot.jar pid启动arthas
2. 选择了java进程回车后报错?target process not responding or HotSpot VM not loaded?
java -jar -XX:+StartAttachListener arthas-boot.jar 方式启动
常用命令
dashboard
查看整体运行情况
- ID: Java级别的线程ID,注意这个ID不能跟jstack中的nativeID一一对应。
- NAME: 线程名
- GROUP: 线程组名
- PRIORITY: 线程优先级, 1~10之间的数字,越大表示优先级越高
- STATE: 线程的状态
- CPU%: 线程的cpu使用率。比如采样间隔1000ms,某个线程的增量cpu时间为100ms,则cpu使用率=100/1000=10%
- DELTA_TIME: 上次采样之后线程运行增量CPU时间,数据格式为秒
- TIME: 线程运行总CPU时间,数据格式为分:秒
- INTERRUPTED: 线程当前的中断位状态
- DAEMON: 是否是daemon线程
thread tid | grep "main"
查看线程(线程ID为1)的栈信息
查询栈中消息
jad
反编译类,用于查看自己修改的代码有没有执行到
watch
查看类下方法的返回值
stop-彻底退出arthas,所有客户端退出 quit和exit-退出当前客户端连接