Arthas 的使用

1,124 阅读2分钟

一、 Arthas 是做什么的?

Arthas(阿尔萨斯)是阿里巴巴开源的 Java 诊断工具

二、Arthas 可以做什么?

当你遇到以下类似问题而束手无策时,Arthas 可以帮助你解决:

  • 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception?

  • 我改的代码为什么没有执行到?难道是我没 commit?分支搞错了?

  • 遇到问题无法在线上 debug,难道只能通过加日志再重新发布吗?

  • 线上遇到某个用户的数据处理有问题,但线上同样无法 debug,线下无法重现!

  • 是否有一个全局视角来查看系统的运行状况?

  • 有什么办法可以监控到JVM的实时运行状态?

Arthas 采用命令行交互模式,同时提供丰富的 Tab 自动补全功能,进一步方便进行问题的定位和诊断。

三、Arthas 如何使用?

地址 alibaba.github.io/arthas/

(1)启动 wget alibaba.github.io/arthas/arth… #下载jar 包

java -jar arthas-boot.jar #启动

根据图中输入 1、2、3 选对应第一张图中的项目进程 进行监控 如监控 6832 的项目进程,输入 1

(2)方法调用(查看参数及返回值)

 格式:watch 类名(全路径) 方法名 **
  • -x 2 -b:跟查看层级有关,比如查看map,list的元素

  • params:参数

  • returnObj:返回值

  • 通过以上格式加上具体方法路劲

      watch com.wiwj.platform.esindexsync.modules.indexdata.dao.LogmqMapper getLogmqList "{params,returnObj}" -x 2 -b
    

例:如下4张图对应 层级参数1、2、3、4效果

案例:如果想把层级调高,就把 -x 后面的数字对应调高

watch com.wiwj.platform.esindexsync.modules.indexdata.service.impl.HousememoServiceImpl syncToHousememoOperation "{params}" -x 2 -b

watch com.wiwj.platform.esindexsync.modules.indexdata.job.RentHouseJobService syncRentHouseOperation "{params,returnObj}" -x 4 -b

3、方法执行时间

  • 格式:trace 类名 方法名 -n 1

  • 监测一次的执行时间 多次的话改 -n 后的数字

      trace com.wiwj.platform.esindexsync.modules.indexdata.job.ExchangeHouseJobService syncBjExchangeHouseTask -n 1