记一次线上CPU100%排查

总结步骤:

  • 查消耗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最高

记一次线上CPU100%排查

 

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

执行命令

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

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

记一次线上CPU100%排查

 

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

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

jstack -l 3033 > ./3033.stack

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

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

输出如下

记一次线上CPU100%排查

 

至此定位到问题