携手创作,共同成长!这是我参与「掘金日新计划 · 8 月更文挑战」的第29天,点击查看活动详情
一、Arthas(阿尔萨斯)是什么
Arthas 是Alibaba开源的Java诊断工具,Arthas支持JDK 6+,支持Linux/Mac/Windows,采用命令行交互模式,同时提供丰富的 Tab 自动补全功能,进一步方便进行问题的定位和诊断。
二、Arthas(阿尔萨斯)能干什么
Arthas作为Java诊断工具,它能帮我们解决以下问题:
- 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception?
- 我改的代码为什么没有执行到?难道是我没 commit?分支搞错了?
- 遇到问题无法在线上 debug,难道只能通过加日志再重新发布吗?
- 线上遇到某个用户的数据处理有问题,但线上同样无法 debug,线下无法重现!
- 是否有一个全局视角来查看系统的运行状况?
- 有什么办法可以监控到JVM的实时运行状态?
- 怎么快速定位应用的热点,生成火焰图?
三、Arthas(阿尔萨斯)怎么使用
1. 下载arthas-boot.jar
wget https://arthas.aliyun.com/arthas-boot.jar;
2. 执行arthas-boot,启动
java -jar arthas-boot.jar
arthas-boot是Arthas的启动程序,它启动后,会列出所有的Java进程,用户可以选择需要诊断的目标进程,这里我们要诊断的是arthas-demo,所以输入2 ,再按回车即可:
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命令。
3、thread命令。后面加上线程ID会打印线程的栈。Arthas支持管道,可以用 thread 1 | grep ‘main(’ 查找到arthas-demo应用的main class。
4、sc命令。用来查找JVM里已加载的类。例如查看名称为MathGame的类:sc -d *MathGame
5、jad命令。用来反编译代码 。例如查看MathGame类的源代码:jad demo.MathGame
6、watch命令。可以查看函数的参数/返回值/异常信息。例如查看MathGame类中primeFactors函数的返回值:watch demo.MathGame primeFactors returnObj ,每次函数被调用都会打印返回值,可以 输入Q 后回车 或 Ctrl+C 退出watch命令。
7、trace命令。查询最耗时应用
在浏览器上进行登录操作,检查最耗时的方法
trace *.DispatcherServlet *
Arthas的命令工具还有很多,详情查看[# Arthas使用教程(8大分类) ]