CPU占用过高排查

CPU占用过高排查步骤

1、top命令查看应用占用CPU情况:  top

2、确定是否是 tomcat 的 java 进程 :  ps aux|grep pid

3、显示该进程的线程列表,确定那个线程占用CPU过高:  ps -mp pid -o THREAD,tid,time

4. 将线程 tid 进行16进制转换:  printf "%x\n" tid

5、显示堆栈信息,定位问题代码:  jstack pid | grep tid -A 30

 

一个应用占用CPU很高,除了确实是计算密集型应用之外,通常原因都是出现了死循环。下面用示例给大家分别介绍一下:

一、top命令执行,如下图:

CPU占用过高排查_第1张图片

 

根据top命令,发现 pid为 28555 的 java进程占用CPU高达200%,出现问题

二、ps aux | grep pid  命令

可以进一步确定是tomcat的java进程出现了问题

 

三、 显示进程的线程列表

ps -mp pid -o THREAD,tid,time , 如下图

CPU占用过高排查_第2张图片

从上图可知:耗时最高和最长时间的线程tid是 28802,占用CPU 60% 和 将近2个小时

四、将线程ID转换为16进制格式

执行 printf "%x\n" tid 命令,如下图:

五、显示堆栈信息,定位问题代码

注意:这里的tid是转换16进制后的线程id

jstack pid |grep tid -A 30

CPU占用过高排查_第3张图片

根据上图定位到了问题代码106行

 

最后,总结下排查CPU故障的方法和技巧有哪些:

1、top命令:Linux命令。可以查看实时的CPU使用情况。也可以查看最近一段时间的CPU使用情况。

2、ps命令: Linux命令。强大的进程状态监控命令。可以查看进程以及进程中线程的当前CPU使用情况。属于当前状态的采样数据。

3、jstack:  Java提供的命令。可以查看某个进程的当前线程栈运行情况。根据这个命令的输出可以定位某个进程的所有线程的当前运行状态、运行代码,以及是否死锁等等。

4、pstack:Linux命令。可以查看某个进程的当前线程栈运行情况。

你可能感兴趣的:(JVM)