官网地址:https://gitee.com/arthas/arthas
命令 | 介绍 |
---|---|
dashboard | 当前系统的实时数据面板 |
thread | 查看当前 JVM 的线程堆栈信息 |
watch | 方法执行数据观测 |
trace | 方法内部调用路径,并输出方法路径上的每个节点上耗时 |
stack | 输出当前方法被调用的调用路径 |
tt | 方法执行数据的时空隧道,记录下指定方法每次调用的入参和返回信息,并能对这些不同的时间下调用进行观测 |
monitor | 方法执行监控 |
jvm | 查看当前 JVM 信息 |
vmoption | 查看,更新 JVM 诊断相关的参数 |
sc | 查看 JVM 已加载的类信息 |
sm | 查看已加载类的方法信息 |
jad | 反编译指定已加载类的源码 |
classloader | 查看 classloader 的继承树,urls,类加载信息 |
heapdump | 类似 jmap 命令的 heap dump 功能 |
wget https://alibaba.github.io/arthas/arthas-boot.jar
java -jar arthas-boot.jar [pid]
利用watch命令,监听指定的方法,-x 参数可以指定打印入参和返回值的深度,第四个参数是条件表达式,过滤数据
watch com.baidu.xxxclass xxxMethod {params,returnObj} params[1]==77777 -x 3
通过jad来反编译Main Class
jad demo.MathGame
sc查找类
sc *Math*
sm查找方法
sm demo.MathGame*
使用 trace 命令可以跟踪统计方法耗时
trace com.UserController getUser
使用 ognl 命令,ognl 表达式可以轻松操作想要的信息:例如查看累的static属性,还可以操作
ognl '@com.Arthas@hashSet'
ognl '@com.Arthas@hashSet.size()'
ognl '@com.Arthas@hashSet.add("test")'
ognl '@com.Arthas@hashSet' | grep test
使用 thread查看所有线程信息,同时会列出每个线程的 CPU
使用率,可以看到图里 ID 为12 的线程 CPU 使用100%。
thread
thread [id]
#寻找 CPU 使用较高的线程
thread -n [显示的线程个数]
#查看线程池里线程信息
thread | grep pool
#查看直接定位到死锁信息
thread -b