前言
当遇到 Java 线上问题时,如 CPU 飙升、负载突高、内存溢出等问题,你需要查命令,查网络,然后 jps、jstack、jmap、jhat、jstat、hprof 等一通操作。而除了这些,Arthas 是一款命令行交互模式的 Java 诊断工具,由于是 Java 编写,所以可以直接*载下**相应 的 jar 包运行,它是Java 线上问题定位处理的终极利器。
当你遇到以下类似问题而束手无策时,Arthas可以帮助你解决:
- 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception?
- 我改的代码为什么没有执行到?难道是我没 commit?分支搞错了?
- 遇到问题无法在线上 debug,难道只能通过加日志再重新发布吗?
- 线上遇到某个用户的数据处理有问题,但线上同样无法 debug,线下无法重现!
- 是否有一个全局视角来查看系统的运行状况?
- 有什么办法可以监控到JVM的实时运行状态?
- 怎么快速定位应用的热点,生成火焰图?
- 怎样直接从JVM内查找某个类的实例?
安装方式
官方安装方式参考:Arthas*载下**:https://arthas.aliyun.com/doc/download.html#id2
上传至服务器,解压到某个文件文件夹(我这里文件夹叫arthas)

切换到解压文件夹,启动Arthas
使用命令:java -jar arthas-boot.jar启动,启动过程中会让你选择监控哪个项目,输入序号即可

启动成功后,可使用官方提供的命令查看内存、线程相关信息
官方命令文档:https://arthas.aliyun.com/doc/commands.html
常用命令

dashboard命令 可以看到,这里会显示出线程(按照cpu占用百分比倒排)、内存(堆空间实时情况)、GC情况等数据。可以按Ctrl+C或者q退出

thread命令查看所有线程信息,同时会列出每个线程的 CPU 使用率,可以看到图里 ID 为12 的线程 CPU 使用率

thread 33命令 查看 CPU 消耗较高的 12 号线程信息,可以看到 CPU 使用较高的方法和行数

thread -n 10命令查看CPU占用率前10的线程的堆栈信息
thread -b命令查看目前block线程
thread -n 5 -i 5000命令查看5s内的CPU使用率top 5线程栈
trace 包名+类名 方法名命令查看方法调用耗时

stop命令关闭Arthas服务端
quit命令退出Arthas客户端
常保存日志
将命令的结果完整保存在日志文件中,便于后续进行分析,默认情况下,该功能是关闭的,如果需要开启,请执行以下命令:
