java 线程池 如何定位消耗CPU最多的线程?
浏览量:2497
时间:2021-04-04 12:13:59
作者:admin
如何定位消耗CPU最多的线程?
在Linux系统下,请按照以下步骤进行检查:
top-C,显示系统运行的进程信息,输入大写P,进程将根据利用率进行排序,可以看到第一列是进程ID,如图所示,消耗CPU最多的进程ID是5986:
top-HP 5986,显示进程的线程运行信息列表,继续输入大写字母p根据CPU利用率对其进行排序,您可以看到第一行,进程5986中消耗CPU最多的线程ID是6021:
下一步,让我们看看您的应用程序做了什么。如果是Java应用程序,要获得更多与线程相关的信息,可以将上面的进程ID转换为十六进制,因为在堆栈中的Jav中,存储线程的ID是十六进制的。您可以直接命令“printf”%Xn“6021”,输出:1785:
接下来,您可以通过线程ID(十六进制)查看堆栈信息。有许多工具可以查看堆栈信息。这里我使用jstack命令“jstack 5986 | grep ”0x1785 “-C5--输出如下:
通过以上步骤,您可以知道当前系统中占用CPU最多的线程以及该线程在做什么,希望能够解决这个问题。
版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。