<返回更多

线上debug诊断神器-Arthas

2021-06-25    胡言胡语的笔记
加入收藏

前言

当遇到 JAVA 线上问题时,如 CPU 飙升、负载突高、内存溢出等问题,你需要查命令,查网络,然后 jps、jstack、jmap、jhat、jstat、hprof 等一通操作。而除了这些,Arthas 是一款命令行交互模式的 Java 诊断工具,由于是 Java 编写,所以可以直接下载相应 的 jar 包运行,它是Java 线上问题定位处理的终极利器。

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

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

安装方式

官方安装方式参考:Arthas下载:
https://arthas.aliyun.com/doc/download.html#id2

上传至服务器,解压到某个文件文件夹(我这里文件夹叫arthas)

线上debug诊断神器-Arthas

 

切换到解压文件夹,启动Arthas

使用命令:java -jar arthas-boot.jar启动,启动过程中会让你选择监控哪个项目,输入序号即可

线上debug诊断神器-Arthas

 

启动成功后,可使用官方提供的命令查看内存、线程相关信息

官方命令文档:
https://arthas.aliyun.com/doc/commands.html

常用命令

线上debug诊断神器-Arthas

 

dashboard命令 可以看到,这里会显示出线程(按照cpu占用百分比倒排)、内存(堆空间实时情况)、GC情况等数据。可以按Ctrl+C或者q退出

线上debug诊断神器-Arthas

 

thread命令查看所有线程信息,同时会列出每个线程的 CPU 使用率,可以看到图里 ID 为12 的线程 CPU 使用率

线上debug诊断神器-Arthas

 

thread 33命令 查看 CPU 消耗较高的 12 号线程信息,可以看到 CPU 使用较高的方法和行数

线上debug诊断神器-Arthas

 

thread -n 10命令查看CPU占用率前10的线程的堆栈信息

thread -b命令查看目前block线程

thread -n 5 -i 5000命令查看5s内的CPU使用率top 5线程栈

trace 包名+类名 方法名命令查看方法调用耗时

线上debug诊断神器-Arthas

 

stop命令关闭Arthas服务端

quit命令退出Arthas客户端

常保存日志

将命令的结果完整保存在日志文件中,便于后续进行分析,默认情况下,该功能是关闭的,如果需要开启,请执行以下命令:

线上debug诊断神器-Arthas
声明:本站部分内容来自互联网,如有版权侵犯或其他问题请与我们联系,我们将立即删除或处理。
▍相关推荐
更多资讯 >>>