Arthas快速诊断线上接口耗时

Arthas 是一款线上监控诊断产品,通过全局视角实时查看应用 load、内存、gc、线程的状态信息,并能在不修改应用代码的情况下,对业务问题进行诊断,包括查看方法调用的出入参、异常,监测方法执行耗时,类加载信息等,大大提升线上问题排查效率。【摘录:Arthas官网

Arthas(阿尔萨斯)能为你做什么?

Arthas 是 Alibaba 开源的 Java 诊断工具,深受开发者喜爱。

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

  1. 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception?
  2. 我改的代码为什么没有执行到?难道是我没 commit?分支搞错了?
  3. 遇到问题无法在线上 debug,难道只能通过加日志再重新发布吗?
  4. 线上遇到某个用户的数据处理有问题,但线上同样无法 debug,线下无法重现!
  5. 是否有一个全局视角来查看系统的运行状况?
  6. 有什么办法可以监控到 JVM 的实时运行状态?
  7. 怎么快速定位应用的热点,生成火焰图?
  8. 怎样直接从 JVM 内查找某个类的实例?

Arthas 支持 JDK 6+,支持 Linux/Mac/Windows,采用命令行交互模式,同时提供丰富的 Tab 自动补全功能,进一步方便进行问题的定位和诊断。 【摘录:Arthas官网


 铁子们,重点来了!

一、问题描述

       1)生产环境正常登录验证后,页面一直加载中。

       2)熟练的使用F12打开控制台后,发现有个接口一直处于Pending中【emo....】

        

       3)经过漫长的等待,终于返回了 41.48秒,这是慢成老牛的节奏啊!!!

        

二、原因定位

        由于是生产环境的原因,没法通过添加日志-》重启服务-》查看日志,判断接口的耗时。所以研究了下Arthas,使用Arthas过后,一切都是真香定律。

        

三、实战记录

 1)下载安装arthas

      curl -O https://arthas.aliyun.com/arthas-boot.jar

        

 
 2)启动arthas
         java -jar arthas-boot.jar

       
     

 
 2)输入以下命令,查看接口耗时,注意在BaseResponse

        trace xxxxx.FieldController  getIndicator  -n 5 --skipJDKMethod false 

        

 3)打开IDEA,优化BaseResponse处的代码,并重新发版后,接口响应时长3.4秒

四、体会总结

        使用Arthas定位问题,十分的高效快捷,特别是在生产环境,解决线上不能随意发版问题。

        今天先到这里,后续再慢慢研究 其他的使用命令,欢迎留言交流!!!

         


Arthas命令参考

命令列表 | arthas (aliyun.com)https://arthas.aliyun.com/doc/commands.html

猜你喜欢

转载自blog.csdn.net/u010953816/article/details/126732783