关于java:Arthas-初探安装初步适用

6次阅读

共计 2326 个字符,预计需要花费 6 分钟才能阅读完成。

作者 | agmtopy

【Arthas 官网社区正在举办征文活动,加入即有奖品拿~ 点击投稿】

因为在我的项目中遇到一种状况,某段代码在进行单元测试和在 tomcat 容器中运行的性能相差数百倍,因而须要剖析在不同环境下某个办法执行的具体工夫,从而确定问题。Arthas 能够做到无侵入的监控利用远行状况。

装置

  • github 我的项目地址:https://github.com/alibaba/arthas
  • 文档地址:alibaba.github.io/arthas/

装置:

wget https://alibaba.github.io/arthas/arthas-boot.jar
java -jar arthas-boot.jar

linux 下间接执行,window 下载文件后执行。

执行实现后,显示以后 path 中指定的 JDK 中正在运行的 java 过程输出相应序号,进入 sh 命令,示意已连贯胜利。

初步应用

Arthas 命令初步应用,大略分为 5 类:

根底命令

  • help——查看命令帮忙信息
  • cat——打印文件内容,和 linux 里的 cat 命令相似
  • pwd——返回以后的工作目录,和 linux 命令相似
  • cls——清空以后屏幕区域
  • session——查看以后会话的信息
  • reset——重置加强类,将被 Arthas 加强过的类全副还原,Arthas 服务端敞开时会重置所有加强过的类
  • version——输入以后指标 Java 过程所加载的 Arthas 版本号
  • history——打印命令历史
  • quit——退出以后 Arthas 客户端,其余 Arthas 客户端不受影响
  • shutdown——敞开 Arthas 服务端,所有 Arthas 客户端全副退出
  • keymap——Arthas 快捷键列表及自定义快捷键

jvm 相干

  • dashboard——以后零碎的实时数据面板
  • thread——查看以后 JVM 的线程堆栈信息
  • jvm——查看以后 JVM 的信息
  • sysprop——查看和批改 JVM 的零碎属性
  • sysenv——查看 JVM 的环境变量
  • getstatic——查看类的动态属性
  • New! ognl——执行 ognl 表达式
  • New! mbean——查看 Mbean 的信息

class/classloader 相干

  • sc——查看 JVM 已加载的类信息
  • sm——查看已加载类的办法信息
  • jad——反编译指定已加载类的源码
  • mc——内存编绎器,内存编绎 .java 文件为 .class 文件
  • redefine——加载内部的 .class 文件,redefine 到 JVM 里
  • dump——dump 已加载类的 byte code 到特定目录
  • classloader——查看 classloader 的继承树,urls,类加载信息,应用 classloader 去 getResource

monitor/watch/trace 相干

请留神,这些命令,都通过字节码加强技术来实现的,会在指定类的办法中插入一些切面来实现数据统计和观测,因而在线上、预发应用时,请尽量明确须要观测的类、办法以及条件,诊断完结要执行 shutdown 或将加强过的类执行 reset 命令。

  • monitor——办法执行监控
  • watch——办法执行数据观测
  • trace——办法外部调用门路,并输入办法门路上的每个节点上耗时
  • stack——输入以后办法被调用的调用门路
  • tt——办法执行数据的时空隧道,记录下指定办法每次调用的入参和返回信息,并能对这些不同的工夫下调用进行观测

options

  • options——查看或设置 Arthas 全局开关

应用实列

  • trace 剖析每个办法的具体执行工夫

通过图示表明调用 MongoTemplate.executeFindMultiInternal() 办法时,最耗时的办法是在 doWith() 办法,总共执行 10000 次,耗时 ==252.3064ms==, 起码一次调用耗时 ==0.0132ms==,最大一次耗时 ==38.4329ms==,剖析起因还是在于数据量太大,MongoTemplate 通过循环遍历出后果在进行序列化。

  • jad 反编译代码工具
jad com.sankuai.inf.leaf.common.ZeroIDGen

  • watch 查看输出参数与输入参数
watch com.sankuai.inf.leaf.server.service.SegmentService getId '{params, target, returnObj}' -x 2

params 示意入参,target 示意以后的类,returnObj 示意返回值。

  • stack 查看被调用的门路 (向上)
stack com.sankuai.inf.leaf.server.service.SegmentService getId

  • sc 查看 JVM 已加载的类信息
sc -d com.sankuai.inf.leaf.server.service.SegmentService getId

  • thread 剖析死锁
thread b


能够看出以后线程正在期待 ReentrantLock$NonfairSync@118f1fb4,而持有这个对象的线程又在期待以后线程开释,从而造成死锁!

  • thread 剖析 CPU 占用

总结

先放一张官网的总结大图:

总结:Arthas 是一个很优良的 java 诊断工具,无论是装置还是应用都很简洁,并且应用文档全面、清晰明了,值得好好钻研一番。

Arthas 征文活动炽热进行中

Arthas 官网正在举办征文活动,如果你有:

  • 应用 Arthas 排查过的问题
  • 对 Arthas 进行源码解读
  • 对 Arthas 提出倡议
  • 不限,其它与 Arthas 无关的内容

    欢送加入征文活动,还有奖品拿哦~ 点击投稿

“阿里巴巴云原生关注微服务、Serverless、容器、Service Mesh 等技术畛域、聚焦云原生风行技术趋势、云原生大规模的落地实际,做最懂云原生开发者的公众号。”

正文完
 0