Arthas安装及简单使用

一. 背景介绍

Arthas 是 Alibaba 在 2018 年 9 月开源的 Java 诊断工具。支持 JDK6+, 采用命令行交互模式,提供 Tab 自动补全,可以方便的定位和诊断线上程序运行问题。得益于 Arthas 强大且丰富的功能,让 Arthas 能做很多的事情,比如以下场景:

  • 是否有一个全局视角来查看系统的运行状况?
  • 为什么 CPU 又升高了,到底是哪里占用了 CPU ?
  • 运行的多线程有死锁吗?有阻塞吗?
  • 程序运行耗时很长,是哪里耗时比较长呢?如何监测呢?
  • 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception?
  • 遇到问题无法在线上 debug,难道只能通过加日志再重新发布吗

二. 安装和启动 

下载链接:https://arthas.aliyun.com/arthas-boot.jar

系统会下载arthas-boot.jar, 要启动arthas就直接运行这个jar包:
java -jar arthas-boot.jar
arthas-boot是Arthas的启动程序,它启动后,会列出所有的Java进程,用户可以选择需要诊断的目标进程。

Arthas安装及简单使用_第1张图片

attach成功后,会看到Arthas的logo,启动成功:

Arthas安装及简单使用_第2张图片

快速退出某个命令:Q或者Ctrl+C
退出Arthas: exit或者quit, 退出当前session,Arthas server还在目标进程中运行。
彻底退出: stop. 用完一定要stop哦,避免Arthas server依然运行占用系统资源。

三. 使用trace命令定位代码耗时

性能测试过程中,经常会碰到接口请求耗时长,但是又不知道具体是哪个环节哪段代码耗时长。这个时候Arthas的trace命令的作用就体现出来了,可以方便快捷从方法表层顺着调用链路一步步往下追踪,最终找出具体耗时长的代码块,是性能测试优化的神器。

举例:假设用例列表页有性能问题,加载列表耗时长,下面介绍如何使用Arthas一步一步定位到具体是哪段代码耗时长:

第一步F12查看请求缓慢的接口:

Arthas安装及简单使用_第3张图片

第二步找到接口对应的controller类全限定名及名称:

trace -n 5 类全限定名 方法名 

-n选项指定捕捉结果的次数

Arthas安装及简单使用_第4张图片

你可能感兴趣的:(java)