Arthas 是一款命令行交互模式的 Java 诊断工具,由于是 Java 编写,所以可以直接下载相应 的 jar 包运行。
安装
这里使用国内的码云 Gitee下载
# Gitee 下载
wget https://arthas.gitee.io/arthas-boot.jar
# 打印帮助信息
java -jar arthas-boot.jar -h
运行
Arthas 是一个 java 程序,所以直接用 java -jar 运行。运行时或者运行之后要选择要监测的 Java 进程。
# 运行方式1,先运行,在选择 Java 进程 PID
java -jar arthas-boot.jar
# 选择进程(输入[]内编号回车)
[INFO] arthas-boot version: 3.3.9
[INFO] Found existing java process, please choose one and input the serial number of the process, eg : 1. Then hit ENTER.
* [1]: 17794 org.apache.zookeeper.server.quorum.QuorumPeerMain
[2]: 23556 sun.tools.jstat.Jstat
[3]: 5558 arthas-boot.jar
[4]: 9948 jenkins.maven3.agent.Maven35Main
[5]: 3870 org.apache.catalina.startup.Bootstrap
[6]: 16702 /home/web/myblog/my-blog-1.0.0-SNAPSHOT.jar
[7]: 14783 /home/web/neteasemusic-import/neteasemusic-0.0.1-SNAPSHOT.jar
# 运行方式2,运行时选择 Java 进程 PID
java -jar arthas-boot.jar [PID]
使用
-
使用
help
可以看到所有可执行的命令 ' -
常用命令
命令 | 介绍 |
---|---|
dashboard | 当前系统的实时数据面板(可以概览程序的 线程、内存、GC、运行环境信息) |
thread | 查看当前 JVM 的线程堆栈信息 |
watch | 方法执行数据观测 |
trace | 方法内部调用路径,并输出方法路径上的每个节点上耗时 |
stack | 输出当前方法被调用的调用路径 |
tt | 方法执行数据的时空隧道,记录下指定方法每次调用的入参和返回信息,并能对这些不同的时间下调用进行观测 |
monitor | 方法执行监控 |
jvm | 查看当前 JVM 信息 |
vmoption | 查看,更新 JVM 诊断相关的参数 |
sc | 查看 JVM 已加载的类信息 |
sm | 查看已加载类的方法信息 |
jad | 反编译指定已加载类的源码 |
classloader | 查看 classloader 的继承树,urls,类加载信息 |
heapdump | 类似 jmap 命令的 heap dump 功能 |
任何一个命令后接-help
可以看到这个命令的更多用法
例如 thread -b
可以列出死锁线程