进程占用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\n" 3850jstack 2651 | grep f0a -A 30