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占用过高排查
文章图片


根据top命令,发现 pid为 28555 的 java进程占用CPU高达200%,出现问题
二、ps aux | grep pid命令
可以进一步确定是tomcat的java进程出现了问题

三、 显示进程的线程列表
ps -mp pid -o THREAD,tid,time , 如下图
CPU占用过高排查
文章图片

从上图可知:耗时最高和最长时间的线程tid是 28802,占用CPU 60% 和 将近2个小时
四、将线程ID转换为16进制格式
执行 printf "%x\n" tid 命令,如下图:
CPU占用过高排查
文章图片

五、显示堆栈信息,定位问题代码
注意:这里的tid是转换16进制后的线程id
jstack pid |grep tid -A 30
CPU占用过高排查
文章图片

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

最后,总结下排查CPU故障的方法和技巧有哪些:
1、top命令:Linux命令。可以查看实时的CPU使用情况。也可以查看最近一段时间的CPU使用情况。
2、ps命令: Linux命令。强大的进程状态监控命令。可以查看进程以及进程中线程的当前CPU使用情况。属于当前状态的采样数据。
3、jstack:Java提供的命令。可以查看某个进程的当前线程栈运行情况。根据这个命令的输出可以定位某个进程的所有线程的当前运行状态、运行代码,以及是否死锁等等。
【CPU占用过高排查】4、pstack:Linux命令。可以查看某个进程的当前线程栈运行情况。

    推荐阅读