关于CPU飙升时的排查过程

Posted flashfish

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于CPU飙升时的排查过程相关的知识,希望对你有一定的参考价值。

如是tomcat 进程占用CPU 过高可以参考以下步骤打印进程堆栈进一步分析问题。

1、先用top查看占用cpu的进程id

2、再用ps -ef | grep PID定位具体的进程主体;如是否是tomcat启动的java程序

3、用ps -mp pid -o THREAD,tid,time打印出该进程下的线程占用cpu情况

4、其次将需要的线程ID转换为16进制格式: printf "%x " tid

5、最后打印线程的堆栈信息: jstack pid |grep tid -A 30 找到出现问题的代码,并分析具体函数中是否有可能出现死循环的代码段。

通常问题出现在while, for之类的循环代码片段

以上是关于关于CPU飙升时的排查过程的主要内容,如果未能解决你的问题,请参考以下文章

Linux---记录一次线上服务 CPU 100%的排查过程

cpu飙升问题排查思路

cpu突然飙升故障排查思路

Java_cpu飙升排查

面试连环炮系列:服务器CPU飙升100%怎么排查

记一次new ArrayList导致的cpu飙升问题排查