进程占用CPU过高,一般有以下两种原因:
1、 业务量过大导致进程处理负荷高,占用CPU资源;
2、 程序BUG导致,比如死循环;
初步查看cpu占用情况
top
进一步分析
对于程序陷入死循环导致CPU占用过高类问题,最好的办法是把进程当前的堆栈信息打印出来,根据堆栈找到代码,快速定位出问题。
Step1:查看线程占用CPU的情况
ps -mp 2651 -o THREAD,tid,time | sort -rn
Step2:查看CPU占用高的线程堆栈
找出CPU消耗最多的线程ID,并将线程ID转换为16进制,最后使用jstack工具打印线程堆栈信息
printf "%x
" 3850
jstack 2651 | grep f0a -A 30