Arthas的作用
Arthas是一款线上监控诊断产品,通过全局视角实时查看应用 load、内存、gc、线程的状态信息,并能在不修改应用代码的情况下,对业务问题进行诊断,包括查看方法调用的出入参、异常,监测方法执行耗时,类加载信息等,大大提升线上问题排查效率。
当你遇到以下类似问题而束手无策时,Arthas可以帮助你解决:
- 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception?
- 我改的代码为什么没有执行到?难道是我没 commit?分支搞错了?
- 遇到问题无法在线上 debug,难道只能通过加日志再重新发布吗?
- 线上遇到某个用户的数据处理有问题,但线上同样无法 debug,线下无法重现!
- 是否有一个全局视角来查看系统的运行状况?
- 有什么办法可以监控到 JVM 的实时运行状态?
- 怎么快速定位应用的热点,生成火焰图?
- 怎样直接从 JVM 内查找某个类的实例?
Arthas使用
官方文档
官方文档
下载
下载链接地址说明
部署
1、将此zip压缩包上传到服务器中。
2、unzip解压
3、启动
java -jar arthas-boot.jar
然后选中对应的进程。
Arthas常用命令
help
查看所有的命令
dashboard
仪表板。可以显示CPU、内存情况。
thread
thread查看线程情况。
thread -n 3 展示当前最忙的前3个线程并打印堆栈
thread -b查看是否存在死锁情况。
trace
可以追踪方法的耗时。如果想要知道具体是哪个耗时多,就不断的跟踪具体的方法,直至输出到具体的方法。
trace cn.station.notify.service.thirdNotifyImpl.ThirdWxNotifySendServiceImpl sendNotice -n 5 --skipJDKMethod false
jad
jad 详细的类名,可以反编译到具体的代码
举例:jad cn.xx.xx.notify.mq.thirdNotify.NotifyWxSendConsumer
watch
观察到指定方法的调用情况
watch cn.station.notify.mq.thirdNotify.ThirdNotifyWxSendConsumer * ‘{params,returnObj,throwExp}’ -n 5 -x 3
monitor
monitor:监控指定类中方法的执行情况monitor
每10秒监控一次
cn.station.notify.mq.thirdNotify.ThirdNotifyWxSendConsumer * -n 10 --cycle 10
相关插件
arthas idea
在idea的设置中找到插件功能,搜索arthas idea安装此功能。此插件可生成执行命令。
举例trace命令,选中对应的代码类或者方法,然后在idea功能栏–Tools–Arthas Command–trace查看方法耗时。
推荐文章
arthas常用命令整理_R_P_J的博客-CSDN博客
Java 诊断工具 Arthas 常见命令使用和实战(排查函数调用异常、热更新、调用方法函数、查看堆栈调用等)