早就听闻阿里开源的Arthas在做Java应用诊断上十分牛逼,身边也有很多同事在使用,因此决定开一个坑,自己从零学习下这个工具的使用,本系列使用的版本是当前最新版3.4.5。
由于Arthas经过这么长时间的发展,本身文档、在线教程已经十分健全了,同时还有第三方的IDEA插件、许多教学视频去帮助我们入门使用,因此这个系列的文章定位是个人笔记,而并非教程,希望不要误人子弟。
概述
https://arthas.aliyun.com
当你遇到以下类似问题而束手无策时,Arthas可以帮助你解决:
这个类从哪个jar包加载的?为什么会报各种类相关的Exception?
我改的代码为什么没有执行到?难道是我没commit?分支搞错了?
遇到问题无法在线上debug,难道只能通过加日志再重新发布吗?
线上遇到某个用户的数据处理有问题,但线上同样无法debug,线下无法重现!
是否有一个全局视角来查看系统的运行状况?
有什么办法可以监控到JVM的实时运行状态?
怎么快速定位应用的热点,生成火焰图?
使用Arthas需要JDK版本在1.6以上。
快速安装
https://arthas.aliyun.com/doc/install-detail.html
Arthas本身也是个Java进程,得益于Java跨平台特性,所以我就直接在Windows上安装了。
(1)下载Arthas包
curl -O https://arthas.aliyun.com/arthas-boot.jar
(2)运行Arthas
java -jar arthas-boot.jar
需要注意的是运行Arthas前至少保证系统正在运行一个Java进程,否则无法启动,并会报错:Cannotfindjavaprocess.Trytopassincommandline.Pleaseselectanavailablepid。解决办法就是跑一个Java应用即可。
如果需要卸载Arthas的话:
在Linux/Unix/Mac平台,删除下面文件:
rm -rf ~/.arthas/rm -rf ~/logs/arthas
Windows平台直接删除userhome下面的.arthas和logs/arthas目录
快速入门
4.1attach进程
这里我们使用Arthas官方提供的demo包,这样我们就不需要自己编写代码了。将demo包下载下来并运行。
curl -O https://arthas.aliyun.com/arthas-demo.jarjava -jar arthas-demo.jar
这个demo功能是死循环做质因数分解,并记录下无法分解的次数,如下图所示。
我们首先启动Arthas并attach上该进程。
默认情况下,Arthas只listen127.0.0.1,所以如果想从远程连接,则可以使用--target-ip参数指定listen的IP
另外如果条件允许的话,在attach后也可以使用浏览器登录,访问:http://127.0.0.1:3658即可。也可以填入IP,远程连接其他机器的Arthas。
4.2常用命令
4.2.1dashboard
https://arthas.aliyun.com/doc/dashboard.html
使用dastboard命令可以查看Java进程信息(定时刷新),如需退出使用q即可。它由如下四个部分组成:
第一部分是显示JVM中运行的所有线程:所在线程组,优先级,线程的状态,CPU的占用率,是否是后台进程等
第二部分显示的JVM内存的使用情况
第三部分显示的是GC相关的信息
第四部分是操作系统的一些信息和Java版本号
4.2.2thread
https://arthas.aliyun.com/doc/thread.html
使用thread命令可以查看当前所有的线程信息。
并且可以通过追加PID的方式,查看具体某个线程的状态。
4.2.3jad
https://arthas.aliyun.com/doc/jad.html
使用jad命令可以反编译class文件。
4.2.2watch
https://arthas.aliyun.com/doc/watch.html
watch命令可以监控方法的入参出参:
退出Arthas
如果只是退出当前的连接,可以用quit或者exit命令。Attach到目标进程上的Arthas还会继续运行,端口会保持开放,下次连接时可以直接连接上。
如果想完全退出arthas,可以执行stop命令。
来源|https://jitwxs.cn/a64edcb1.html
热门跟贴