文章目录
简介
提示:简介内容来自官方文档:
- Arthas 是一款线上监控诊断产品,通过全局视角实时查看应用 load、内存、gc、线程的状态信息,并能在不修改应用代码的情况下,对业务问题进行诊断,包括查看方法调用的出入参、异常,监测方法执行耗时,类加载信息等,大大提升线上问题排查效率。
背景
-
通常,本地开发环境无法访问生产环境。如果在生产环境中遇到问题,则无法使用 IDE 远程调试。更糟糕的是,在生产环境中调试是不可接受的,因为它会暂停所有线程,导致服务暂停。
-
开发人员可以尝试在测试环境或者预发环境中复现生产环境中的问题。但是,某些问题无法在不同的环境中轻松复现,甚至在重新启动后就消失了。
-
如果您正在考虑在代码中添加一些日志以帮助解决问题,您将必须经历以下阶段:测试、预发,然后生产。这种方法效率低下,更糟糕的是,该问题可能无法解决,因为一旦 JVM 重新启动,它可能无法复现,如上文所述。
-
Arthas 旨在解决这些问题。开发人员可以在线解决生产问题。无需 JVM 重启,无需代码更改。 Arthas 作为观察者永远不会暂停正在运行的线程。
提示:以下是本篇文章正文内容,下面案例可供参考
一、Arthas能干什么?
Arthas 是 Alibaba 开源的 Java 诊断工具,深受开发者喜爱。
当你遇到以下类似问题而束手无策时,Arthas可以帮助你解决:
- 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception?
- 我改的代码为什么没有执行到?难道是我没 commit?分支搞错了?
- 遇到问题无法在线上 debug,难道只能通过加日志再重新发布吗?
- 线上遇到某个用户的数据处理有问题,但线上同样无法 debug,线下无法重现!
- 是否有一个全局视角来查看系统的运行状况?
- 有什么办法可以监控到 JVM 的实时运行状态?
- 怎么快速定位应用的热点,生成火焰图?
- 怎样直接从 JVM 内查找某个类的实例?
二、Arthas获取方式
1、Arthas 离线安装
- Arthas官网地址:https://arthas.aliyun.com/en/
- 从 Github Releases 下载地址:https://github.com/alibaba/arthas/releases
- 由于网络原因,可能会导致页面打不开或下载失败,我这里已经下载了几个版本供大家选择
- 下载地址:https://www.123pan.com/s/qzKxjv-sHyXH.html
2、Arthas 在线安装
- 在命令行下面执行(使用和目标进程一致的用户启动,否则可能 attach 失败):下载
- 下载命令
curl -O https://arthas.aliyun.com/arthas-boot.jar
- 启动 arthas,首先必须提前启动一个java的进程,然后启动
arthas-boot.jar
,选择1
启动并安装 - 命令
java -jar arthas-boot.jar
- 通过
ls -a
查看Linux 下面的隐藏文件,看到.arthas
目录,就是arthas的安装路径 - 日志在:
logs/arthas
和logs/arthas-cache
目录中
三、Arthas使用步骤
1、启动 math-game
- 首先进入 Arthas 的安装目录
/root/.arthas/lib/3.7.1/arthas
,启动 math-game,测试
2、启动 Arthas,黏附项目进行诊断
- 首先进入 Arthas 的安装目录
/root/.arthas/lib/3.7.1/arthas
,启动 arthas-boot.jar - 如果是非正常退出,会报上面的错误,提示端口占用。原因是上次连接了一个进程,未正常退出。
quit:只是退出当前的连接。Attach到目标进程上的arthas还会继续运行,端口会保持开放,下次连接时执行java -jar arthas-boot.jar可以直接连接上。
exit:和quit命令一样的功能;
stop:完全退出arthas,
- 解决方法1:更换端口号
java -jar arthas-boot.jar --telnet-port 9998 --http-port -1
- 解决方法2:完全退出
arthas
使用stop
命令, 重新启动arthas-boot.jar
即可 - 浏览器使用
四、Arthas命令使用
1、dashboard 仪表盘 显示JVM虚拟机中内存使用情况
- 如下图
2、thread 查看运行的所有线程
- 如图显示
- 根据线程的ID查看线程
3、jad 反编指定的类或者方法
- 通过包名,和类名进行反编译,指定的文件,jad demo.MathGame
ClassLoader
: 下面显示的是类加载器Location
: 下面显示的是启动的jar
4、watch 命令能方便的观察到指定方法的,输入输出参数的调用情况
- watch demo.MathGame primeFactors returnObj 包名 方法名 返回结果
returnObj
总结
上面简单的介绍了 Arthas 的使用,具体详细的操作见官方文档:https://arthas.aliyun.com/doc/