一、 Arthas 是做什么的?
Arthas(阿尔萨斯)是阿里巴巴开源的 Java 诊断工具
二、Arthas 可以做什么?
当你遇到以下类似问题而束手无策时,Arthas 可以帮助你解决:
-
这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception?
-
我改的代码为什么没有执行到?难道是我没 commit?分支搞错了?
-
遇到问题无法在线上 debug,难道只能通过加日志再重新发布吗?
-
线上遇到某个用户的数据处理有问题,但线上同样无法 debug,线下无法重现!
-
是否有一个全局视角来查看系统的运行状况?
-
有什么办法可以监控到JVM的实时运行状态?
Arthas 采用命令行交互模式,同时提供丰富的 Tab 自动补全功能,进一步方便进行问题的定位和诊断。
三、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