排查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
作者:Lave Zhang
出处:http://www.cnblogs.com/lavezhang/
本文版权归作者所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。