Java线上问题诊断工具Arthas

常见线上问题

常见的系统异常现象包括: CPU占用率过高、CPU上下文切换频率次数较高、磁盘 I/O 过于频繁、网络流量异常(连接数过多)、系统可用内存长期处于较低值(导致 oom killer)等等。

Arthas简介

Arthas 是Alibaba开源的Java诊断工具,深受开发者喜爱。(摘自【官方文档】)
当你遇到以下类似问题而束手无策时,Arthas可以帮助你解决:

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

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

Instrumentation

参考文档:https://www.jianshu.com/p/5c62b71fd882

Arthas使用

官网提供了比较多的安装形式可以参考,这里提供一种我比较喜欢的一种方式,首先环境需要有Java环境支持。

curl -O https://arthas.aliyun.com/arthas-boot.jar      //下载
java -jar arthas-boot.jar                              //启动

当看到控制台出现arthas的标志,表明启动成功!注意此时已经进入控制台,主要是arthas的命令使用。

[root@xxptweb01 arthas]# java -jar arthas-boot.jar                                                             
[INFO] arthas-boot version: 3.3.9                                                                              
[INFO] Found existing java process, please choose one and input the serial number of the process, eg : 1. Then 
hit ENTER.                                                                                                     
* [1]: 32767 org.apache.catalina.startup.Bootstrap                                                             
1                                                                                                              
[INFO] arthas home: /root/.arthas/lib/3.3.9/arthas                                                             
[INFO] Try to attach process 32767                                                                             
[INFO] Attach process 32767 success.                                                                           
[INFO] arthas-client connect 127.0.0.1 3658                                                                    
  ,---.  ,------. ,--------.,--.  ,--.  ,---.   ,---.                                                          
 /  O  \ |  .--. ''--.  .--'|  '--'  | /  O  \ '   .-'                                                         
|  .-.  ||  '--'.'   |  |   |  .--.  ||  .-.  |`.  `-.                                                         
|  | |  ||  |\  \    |  |   |  |  |  ||  | |  |.-'    |                                                        
`--' `--'`--' '--'   `--'   `--'  `--'`--' `--'`-----'                                                         
                                                                                                               
                                                                                                               
wiki      https://arthas.aliyun.com/doc                                                                        
tutorials https://arthas.aliyun.com/doc/arthas-tutorials.html                                                  
version   3.3.9                                                                                                
pid       32767                                                                                                
time      2020-08-31 21:39:55                                                                                  
                                                                                                               
[arthas@32767]$

Arthas基础命令:

  • help——查看命令帮助信息
  • cls——清空当前屏幕区域
  • session——查看当前会话的信息
  • reset——重置增强类,将被 Arthas 增强过的类全部还原,Arthas 服务端关闭时会重置所有增强过的类
  • version——输出当前目标 Java 进程所加载的 Arthas 版本号
  • history——打印命令历史
  • quit——退出当前 Arthas 客户端,其他 Arthas 客户端不受影响
  • stop——关闭 Arthas 服务端,所有 Arthas 客户端全部退出
  • keymap——Arthas快捷键列表及自定义快捷键

详细命令:https://arthas.aliyun.com/doc/commands.html

如果感觉这些命令使用起来比较难记,有困难,可以使用IDEA插件:arthas idea plugin 使用文档

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

星光Starsray

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值