记一次线上CPU100%排查

mac2024-03-26  31

总结步骤:

查消耗cpu最高的进程Pid根据Pid查出消耗cpu最高的线程号根据线程号查出对应的java线程,进行处理。

误写的一行死循环代码

public class TestFor { public static void main(String[] args) { int random = 0; while (random < 100) { random = random * 10; } } }

查消耗Cpu最高的进程PID

执行命令

执行top -c ,显示进程运行信息列表。按下P,进程按照Cpu使用率排序

如下图所示,PID为3033的进程耗费Cpu最高

 

根据Pid查出消耗Cpu最高的线程号

执行命令

top -Hp 3033 ,显示一个进程的线程运行信息列表。按下P,进程按照Cpu使用率排序

如下图所示,PID为3034的线程耗费Cpu最高

 

这是十进制的数据,转成十六进制为0Xbda

根据线程号查出对应的java线程,进行处理

jstack -l 3033 > ./3033.stack

然后执行,grep命令,看线程0xbda做了什么

cat 3033.stack |grep 'bda' -C 8

输出如下

 

至此定位到问题

 

最新回复(0)