线上服务 CPU 问题定位
identification /aɪˌdentɪfɪˈkeɪʃn/ n. 鉴定,识别;认同;身份证明
PID(Process Identification) 进程标识符
TID(Thread Identification) 线程标识符
REFERENCE:
-
找到最耗 CPU 的进程
top -c # 显示进程运行信息列表
键入
P
,进程按照 CPU 使用率排序 -
找到最耗 CPU 的线程
top -Hp PID # 显示该进程的线程运行信息列表
键入
P
,线程按照 CPU 使用率排序 -
将线程 PID(实际上是 TID)转换为 16 进制(Hexadecimal)
printf "%x\n" TID
printf "%x\n" 20000 4e20
得到 0xPID,转换为 16 进制的原因,在堆栈中,TID 以 16 进制表示
-
查看堆栈
ptack/jstack/grep
jstack PID | grep '0xTID' -C5 --color
jstack 20000 | grep 4e20 -C5 --color
打印进程堆栈;通过打印 TID,过滤线程堆栈