介绍
Arthas 是Alibaba开源的Java诊断工具,深受开发者喜爱。
可以解决的问题:
- 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception?
- 我改的代码为什么没有执行到?难道是我没 commit?分支搞错了?
- 遇到问题无法在线上 debug,难道只能通过加日志再重新发布吗?
- 线上遇到某个用户的数据处理有问题,但线上同样无法 debug,线下无法重现!
- 是否有一个全局视角来查看系统的运行状况?
- 有什么办法可以监控到JVM的实时运行状态?
使用
在linux上首先下载arthas-boot的jar包,然后通过命令来启动它
wget https://alibaba.github.io/arthas/arthas-boot.jar
wget https://arthas.gitee.io/arthas-boot.jar
curl -L https://alibaba.github.io/arthas/install.sh | sh
没有wget命令自行安装
brew install wget
前两种方式都是通过https/gitee镜像/去下载arthas-boot的jar
最后一种是比较推荐的因为他会直接下载到本地称为一个as.sh 的脚本
java -jar arthas-boot.jar
命令清单
- help——查看命令帮助信息
jvm相关
- dashboard ——查看当前系统实时数据
- 线程模块:包括线程id、名字、组、优先级、状态(RUNNABL/WAITING/TIMED_W)、CPU使用率、线程运行时间分:秒、INTERRUPTED当前线程中断位状态、是否为守护线程
- 内存模块:堆栈的信息还有一些GC的内容,使用内存、总内存、最大内存、使用率、gc.copy.count、gc.copy.time(ms)、gc.marksweepcompact.co、unt
- 运行时模块 :系统名、系统版本、java版本、javahome、systemload.average
- thread ——thread pid 可以查看线程的栈,支持使用管道命令, -n 找出前几个cpu使用率最高的 -d 一键找出找出当前阻塞其他线程的线程
- jvm ——查看当前 JVM 的信息
- sysprop——查看和修改JVM的系统属性
- sysenv——查看JVM的环境变量
- getstatic——查看类的静态属性
class/classloader相关
- sc ——查看JVM中加载的类 sc -d *MathGame
- sm——查看已加载类的方法信息
- jad ——可以反编译代码 jad demo.MathGame
- watch——可以查看函数的参数/返回值/异常信息 watch demo.MathGame primeFactors returnObj
- mc——内存编绎器,内存编绎.java文件为.class文件
- redefine——加载外部的.class文件,redefine到JVM里
- dump——dump 已加载类的 byte code 到特定目录
- classloader——查看classloader的继承树
- exit/shutdown ——退出arthas 区别是exit不会中断一次session 而shutdown是彻底关闭arthas
monitor/watch/trace相关
请注意,这些命令,都通过字节码增强技术来实现的,会在指定类的方法中插入一些切面来实现数据统计和观测,因此在线上、预发使用时,请尽量明确需要观测的类、方法以及条件,诊断结束要执行 shutdown 或将增强过的类执行 reset 命令。
monitor——方法执行监控
watch——方法执行数据观测
trace——方法内部调用路径,并输出方法路径上的每个节点上耗时
stack——输出当前方法被调用的调用路径
tt——方法执行数据的时空隧道,记录下指定方法每次调用的入参和返回信息,并能对这些不同的时间下调用进行观测
命令速查表
https://alibaba.github.io/arthas/commands.html