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