1.top命令后,找到java进程对应的pid
也可以:
ps -ef | grep java 找到你的java程序的进程id, 定位 pid
top -Hp $pid
2.shift+h查看单核线程列表,找到占用cpu最多的java线程对应的id
3.将该id用计算器转换成16进制
4.然后执行JDK的jstack得到堆栈信息 jstack -m <pid>
5.在堆栈中查找该16进制线程id对应的线程
6.然后过了一段时间再做一次, 如果发现同一个thread NID 还是停在同一个地方, 基本上可以怀疑是否挂住了(一般只需要查看你业务相关的stack信息就行了).
嗯嗯,发现一个帖子:
http://flysnowxf.iteye.com/blog/1162691
也可以:
ps -ef | grep java 找到你的java程序的进程id, 定位 pid
top -Hp $pid
2.shift+h查看单核线程列表,找到占用cpu最多的java线程对应的id
3.将该id用计算器转换成16进制
4.然后执行JDK的jstack得到堆栈信息 jstack -m <pid>
5.在堆栈中查找该16进制线程id对应的线程
6.然后过了一段时间再做一次, 如果发现同一个thread NID 还是停在同一个地方, 基本上可以怀疑是否挂住了(一般只需要查看你业务相关的stack信息就行了).
嗯嗯,发现一个帖子:
http://flysnowxf.iteye.com/blog/1162691
本文介绍了一套详细的步骤来定位导致Java程序CPU使用率升高的具体原因。首先通过top命令找到Java进程的PID,接着利用ps命令组合grep获取进程ID。使用shift+h查看单核线程列表并找到占用CPU最多的线程ID。将该ID转换为16进制,通过JDK自带的jstack工具获取线程的堆栈信息。最后,在堆栈信息中寻找16进制线程ID对应的具体线程位置。

1383

被折叠的 条评论
为什么被折叠?



