做者 | agmtopy java
【Arthas 官方社区正在举行征文活动,参加即有奖品拿~点击投稿】linux
因为在项目中遇到一种状况,某段代码在进行单元测试和在 tomcat 容器中运行的性能相差数百倍,所以须要分析在不一样环境下某个方法执行的具体时间,从而肯定问题。Arthas 能够作到无侵入的监控应用远行状况。git
安装:github
wget https://alibaba.github.io/arthas/arthas-boot.jar java -jar arthas-boot.jar
linux 下直接执行,window 下载文件后执行。tomcat
执行完成后,显示当前 path 中指定的 JDK 中正在运行的 java 进程输入相应序号,进入 sh 命令,表示已链接成功。session
Arthas 命令初步使用,大概分为 5 类:less
请注意,这些命令,都经过字节码加强技术来实现的,会在指定类的方法中插入一些切面来实现数据统计和观测,所以在线上、预发使用时,请尽可能明确须要观测的类、方法以及条件,诊断结束要执行 shutdown 或将加强过的类执行 reset 命令。jvm
经过图示代表调用 MongoTemplate.executeFindMultiInternal() 方法时,最耗时的方法是在 doWith() 方法,总共执行 10000 次,耗时 ==252.3064ms==,最少一次调用耗时 ==0.0132ms==,最大一次耗时 ==38.4329ms==,分析缘由仍是在于数据量太大,MongoTemplate 经过循环遍历出结果在进行序列化。ide
jad com.sankuai.inf.leaf.common.ZeroIDGen
watch com.sankuai.inf.leaf.server.service.SegmentService getId '{params, target, returnObj}' -x 2
params 表示入参,target 表示当前的类,returnObj 表示返回值。微服务
stack com.sankuai.inf.leaf.server.service.SegmentService getId
sc -d com.sankuai.inf.leaf.server.service.SegmentService getId
thread b
能够看出当前线程正在等待 ReentrantLock$NonfairSync@118f1fb4,而持有这个对象的线程又在等待当前线程释放,从而造成死锁!
先放一张官方的总结大图:
总结:Arthas 是一个很优秀的 java 诊断工具,不管是安装仍是使用都很简洁,而且使用文档全面、清晰明了,值得好好研究一番。
Arthas 官方正在举行征文活动,若是你有:
不限,其它与 Arthas 有关的内容
欢迎参加征文活动,还有奖品拿哦~点击投稿
“阿里巴巴云原生关注微服务、Serverless、容器、Service Mesh 等技术领域、聚焦云原生流行技术趋势、云原生大规模的落地实践,作最懂云原生开发者的公众号。”