cpu分析简介

进程占用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

原文地址:https://www.cnblogs.com/kabi/p/5241357.html