1、使用jps查找正在运行的java进程,
2、通过使用top命令查找该线程下CPU使用最高的线程 如图2
3、 TIME列就是各个Java线程耗费的CPU时间,(用 printf “%x” pID 转16 进制)显然CPU时间最长的是ID为2968的线程,用 printf “%x\n” xxx
4、终于轮到jstack上场了,它用来输出进程7127的堆栈信息,然后根据线程ID的十六进制值grep,如下:
[root@storm-master home]# jstack 23749 | grep 5cce -A 10
jstack后面的23749是第1步定位到的进程号,grep后面的是(2)、(3)步定位到的线程号。
可以看到CPU消耗,于是就能很容易的定位到相关的代码了。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/124589.html