2025-06-15
工具运维
0

目录

Arthas
下载和安装
使用arthas-boot(推荐)
使用as.sh
快速入门
常用命令与功能
Dashboard
Thread
JVM
Jad
trace
monitor
watch
idea 插件
命令汇总

通常,本地开发环境无法访问生产环境。如果在生产环境中遇到问题,则无法使用 IDE 远程调试。更糟糕的是,在生产环境中调试是不可接受的,因为它会暂停所有线程,导致服务暂停。

开发人员可以尝试在测试环境或者预发环境中复现生产环境中的问题。但是,某些问题无法在不同的环境中轻松复现,甚至在重新启动后就消失了。

如果您正在考虑在代码中添加一些日志以帮助解决问题,您将必须经历以下阶段:测试、预发,然后生产。这种方法效率低下,更糟糕的是,该问题可能无法解决,因为一旦 JVM 重新启动,它可能无法复现,如上文所述。

Arthas 旨在解决这些问题。开发人员可以在线解决生产问题。无需 JVM 重启,无需代码更改。 Arthas 作为观察者永远不会暂停正在运行的线程。

Arthas

Arthas 是 Alibaba 开源的 Java 诊断工具,深受开发者喜爱。

当你遇到以下类似问题而束手无策时,Arthas可以帮助你解决:

  • 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception?
  • 我改的代码为什么没有执行到?难道是我没 commit?分支搞错了?
  • 遇到问题无法在线上 debug,难道只能通过加日志再重新发布吗?
  • 线上遇到某个用户的数据处理有问题,但线上同样无法 debug,线下无法重现!
  • 是否有一个全局视角来查看系统的运行状况?
  • 有什么办法可以监控到 JVM 的实时运行状态?
  • 怎么快速定位应用的热点,生成火焰图?
  • 怎样直接从 JVM 内查找某个类的实例?

Arthas 支持 JDK 6+(4.x 版本不再支持 JDK 6 和 JDK 7),支持 Linux/Mac/Windows,采用命令行交互模式,同时提供丰富的 Tab 自动补全功能,进一步方便进行问题的定位和诊断。

官方文档:https://arthas.aliyun.com/doc/quick-start.html

下载和安装

使用arthas-boot(推荐)

下载arthas-boot.jar,然后用java -jar的方式启动:

sh
curl -O https://arthas.aliyun.com/arthas-boot.jar java -jar arthas-boot.jar

使用as.sh

Arthas 支持在 Linux/Unix/Mac 等平台上一键安装,请复制以下内容,并粘贴到命令行中,敲 回车 执行即可:

sh
curl -L https://arthas.aliyun.com/install.sh | sh

上述命令会下载启动脚本文件 as.sh 到当前目录,你可以放在任何地方或将其加入到 $PATH 中。

直接在 shell 下面执行./as.sh,就会进入交互界面。

也可以执行./as.sh -h来获取更多参数信息。

快速入门

1、直接java -jar arthas-boot.jar。选择attach的进程绑定

一般是出现arthas的这种,就是进入了想要监控的进程中

image.png

常用命令与功能

Dashboard

注意在arthas中,有tab键填充功能,所以比较好用。但是这个界面是实时刷新的,一般5s刷新一次,使用q键退出刷新(没有退出arthasq)

image.png

Thread

这个命令和jstack很相似,但是功能更加强大,主要是查看当前JVM的线程堆栈信息

同时可以结合使用thread –b 来进行死锁的排查死锁。

参数解释:

  • -n 指定最忙的前n个线程并打印堆栈

  • -b 找出阻塞当前线程的线程

  • -i 指定cpu占比统计的采样间隔,单位为毫秒

thread – b  找出阻塞当前线程的线程

image.png

thread -i 1000 -n 3 每过1000毫秒进行采样,显示最占CPU时间的前3个线程

image.png

thread --state WAITING 查看处于等待状态的线程

image.png

JVM

显示当前JVM的进程信息

image.png

Jad

反编译指定已加载类的源码

image.png

trace

使用 trace 命令可以跟踪统计方法耗时

image.png

比如使用一个Springboot 项目控制层 getUser 方法调用了 userService.get(uid);,这个方法中分别进行check、service、redis、mysql等操作操作。就可以根据这个命令跟踪出来哪里的耗时最长。

monitor

监控方法的执行情况

每5秒统计一次cn.enjoyedu.demo.controller.DemoController类的test方法执行情况

image.png

watch

观察方法的入参出参信息

查看入参和出参

sh
watch cn.enjoyedu.demo.controller.DemoController test '{params[0],returnObj}'

image.png

image.png

image.png

idea 插件

在 idea 插件中搜索 arthas

image.png

鼠标指针聚焦在方法上,右键选中 Arthas Command 后根据想要操作的命令,可基于当前方法自动生成,也可直接选中指令,会自动将命令复制到剪贴板,随时使用

image.png

image.png

命令汇总

命令介绍
dashboard当前系统的实时数据面板
thread查看当前JVM的线程堆栈信息
watch方法执行数据观测
trace方法内部调用路径,并输出方法路径上的每个节点上耗时
stack输出当前方法被调用的调用路径
tt方法执行数据的时空隧道,记录下指定方法每次调用的入参和返回信息,并能对这些不同的时间下调用进行观测
monitor方法执行监控
jvm查看当前JVM信息
vmoption查看,更新JVM诊断相关的参数
sc查看JVM已加载的类信息
sm查看已加载类的方法信息
jad反编译指定已加载类的源码
classloader查看classloader的继承树,urls,类加载信息
heapdump类似jmap命令的 heap dump 功能

本文作者:柳始恭

本文链接:

版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!