排查tomcat服务器CPU占用率过高的问题

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

posted @ 2021-12-30 11:18  卡卡西村长  阅读(657)  评论(0)    收藏  举报