1、执行top命令,看具体是哪个进程导致CPU 100%,复制问题进程的PID。

2、执行命令:top -p PID -H      查看指定进程里面的线程状态,定位到CPU太高的线程,开头的PID实际就是线程ID(TID)。

3、执行命令:printf "%x\n" TID     把TID转换为十六进制。

4、执行命令:jstack PID | grep TID -A 30     显示指定进程的栈信息,看是否有锁,或者其它耗时操作。

5、执行命令:jmap -heap PID    查看堆信息。

对于jstack和jmap工具,oracle JDK和open JDK存在一些差异,本文用的是oracle JDK。

 

这篇写得更详细:

https://www.cnblogs.com/wuchanming/p/7766994.html

相关文章: