线上debug诊断神器-Arthas

前言当遇到 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【线上debug诊断神器-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

文章插图




    推荐阅读