Java诊断工具Arthas入门教程

4,190 阅读3分钟

携手创作,共同成长!这是我参与「掘金日新计划 · 8 月更文挑战」的第29天,点击查看活动详情

一、Arthas(阿尔萨斯)是什么

Arthas 是Alibaba开源的Java诊断工具,Arthas支持JDK 6+,支持Linux/Mac/Windows,采用命令行交互模式,同时提供丰富的 Tab 自动补全功能,进一步方便进行问题的定位和诊断。

二、Arthas(阿尔萨斯)能干什么

Arthas作为Java诊断工具,它能帮我们解决以下问题:

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

三、Arthas(阿尔萨斯)怎么使用

1. 下载arthas-boot.jar

    wget https://arthas.aliyun.com/arthas-boot.jar;

2. 执行arthas-boot,启动

    java -jar arthas-boot.jar

image.png arthas-boot是Arthas的启动程序,它启动后,会列出所有的Java进程,用户可以选择需要诊断的目标进程,这里我们要诊断的是arthas-demo,所以输入2 ,再按回车即可:

image.png

3. 退出Arthas

可以使用 exit 或者 quit 命令退出Arthas。exit/quit命令只是退出当前session,arthas server还在目标进程中运行。退出Arthas之后,还可以再次用 java -jar arthas-boot.jar 来连接。如果要彻底退出Arthas,可以执行 stop 命令。需要注意的是,执行exit/quit命令后无法再执行stop命令。

4. 卸载Arthas

    直接删除安装目录既可
    rm -rf ./arthas			#	隐藏目录
    rm -rf logs/			#	日志目录

四、Arthas(阿尔萨斯)常用命令

1、 help命令。 可以获取到更多的帮助信息。

2、 dashboard命令。可以查看当前系统的实时数据面板。数据面板默认5秒刷新一次。可以 输入Q 后回车 或 Ctrl+C 退出dashboard命令。

image.png

3、thread命令。后面加上线程ID会打印线程的栈。Arthas支持管道,可以用 thread 1 | grep ‘main(’ 查找到arthas-demo应用的main class。

image.png

4、sc命令。用来查找JVM里已加载的类。例如查看名称为MathGame的类:sc -d *MathGame

image.png

5、jad命令。用来反编译代码 。例如查看MathGame类的源代码:jad demo.MathGame

image.png

6、watch命令。可以查看函数的参数/返回值/异常信息。例如查看MathGame类中primeFactors函数的返回值:watch demo.MathGame primeFactors returnObj ,每次函数被调用都会打印返回值,可以 输入Q 后回车 或 Ctrl+C 退出watch命令。

image.png

7、trace命令。查询最耗时应用

在浏览器上进行登录操作,检查最耗时的方法
trace *.DispatcherServlet *

Arthas的命令工具还有很多,详情查看[# Arthas使用教程(8大分类) ]