前言
系统的稳定性还在于线上问题的快速排查, 比如线上 oom, 线程死锁, 连接池耗尽等等都可能会造成严重的生产事故.为此我打算系统学习一下 Arthas 和相关的知识
安装
curl -O https://arthas.aliyun.com/arthas-boot.jar
java -jar arthas-boot.jar
Thread 命令学习:
选择好 attach 的进程, 进入 arthas 命令界面, 执行 help thread 展示了详细的命令.
字段解释:
Internal threads : 代表 JVM 内部线程
ID: 线程id, 可以使用 thread ID 查看线程执行栈
NAME: 线程名称
GROUP: 线程组
PRIORITY: 优先级
STATE: 线程状态,http://mcace.me/java并发/2018/08/24/java-thread-states.html
%CPU: cpu 使用率
DELTA_TIME: 为采样间隔时间内线程的增量 CPU 时间,小于 1ms 时被取整显示为 0ms。
TIME: 线程运行总 CPU 时间。
INTERRUPTED: 是否被中断
DAEMON: 是否是守护线程(User threads是高优先级的thread,JVM将会等待所有的User Threads运行完毕之后才会结束运行。daemon thr