关于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\n" tid
5、最后打印线程的堆栈信息: jstack pid |grep tid -A 30 找到出现问题的代码,并分析具体函数中是否有可能出现死循环的代码段。
通常问题出现在while, for之类的循环代码片段