当遇到 JAVA 线上问题时,如 CPU 飙升、负载突高、内存溢出等问题,你需要查命令,查网络,然后 jps、jstack、jmap、jhat、jstat、hprof 等一通操作。而除了这些,Arthas 是一款命令行交互模式的 Java 诊断工具,由于是 Java 编写,所以可以直接下载相应 的 jar 包运行,它是Java 线上问题定位处理的终极利器。
当你遇到以下类似问题而束手无策时,Arthas可以帮助你解决:
官方安装方式参考:Arthas下载:
https://arthas.aliyun.com/doc/download.html#id2
使用命令:java -jar arthas-boot.jar启动,启动过程中会让你选择监控哪个项目,输入序号即可
官方命令文档:
https://arthas.aliyun.com/doc/commands.html
dashboard命令 可以看到,这里会显示出线程(按照cpu占用百分比倒排)、内存(堆空间实时情况)、GC情况等数据。可以按Ctrl+C或者q退出
thread命令查看所有线程信息,同时会列出每个线程的 CPU 使用率,可以看到图里 ID 为12 的线程 CPU 使用率
thread 33命令 查看 CPU 消耗较高的 12 号线程信息,可以看到 CPU 使用较高的方法和行数
thread -n 10命令查看CPU占用率前10的线程的堆栈信息
thread -b命令查看目前block线程
thread -n 5 -i 5000命令查看5s内的CPU使用率top 5线程栈
trace 包名+类名 方法名命令查看方法调用耗时
stop命令关闭Arthas服务端
quit命令退出Arthas客户端
将命令的结果完整保存在日志文件中,便于后续进行分析,默认情况下,该功能是关闭的,如果需要开启,请执行以下命令: