由于涉及到私有代码,所有图片都隐去
1、执行TOP命令,确认CPU占用较高的进程PID
根据top命令,发现PID为8691的Java进程占用CPU高达3858%,出现故障
2、确认该进程中CPU占用率高的线程
找到该进程后,如何定位具体线程或代码呢?首先显示线程列表,并按照CPU占用高的线程排序。执行如下命令:
ps -mp 8691 -o THREAD,tid,time | sort –rn
从该列表中可以看出TIME列,所有线程占用时间都比较高,达到了3个小时以上。可以选择其中一个线程(TID)进行分析
3、将线程ID转换为16进制格式
执行命令:printf "%x\n" 8729
4、查看线程的堆栈信息
执行命令:jstack PID |grep 线程ID的16进制步骤3的结果 -A 30
黄色部分需要替换为进程ID和线程ID的16进制,如下图:
5、查看堆栈信息
根据步骤4 的堆栈信息,确认问题。如下:
"20150807#174500#1500#XXXX#1434545713195[35/1144]" prio=10 tid=0x00000000008ba000 nid=0x3b5e waiting for monitor entry [0x00007f5b7cac2000]
java.lang.Thread.State: BLOCKED (on object monitor)
at com.xxx.xxx.xxxx.xxxx()
从上面的堆栈信息中可以看出哪段代码有问题。进而再分析代码。