【jvm优化】top命令找到占用CPU最高的java线程

1、使用jps查找正在运行的java进程,



2、通过使用top命令查找该线程下CPU使用最高的线程 如图2

【jvm优化】top命令找到占用CPU最高的java线程_第1张图片

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消耗,于是就能很容易的定位到相关的代码了。

你可能感兴趣的:(编程,jvm,java,开发语言)