java查看线程状态 如何定位消耗CPU最多的线程?
如何定位消耗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最多的线程以及该线程在做什么,希望能够解决这个问题。
java线程死锁和内存溢出,该怎么解决?
Java线程死锁或线程太多:
1。获取java进程ID
PS-EF | grep java
2。导出线程堆栈(32494被上一步中找到的进程ID替换)
jstack-L 32494>>/usr/local/client/log20180116。日志
3。生成导出。日志从上一步复制文件到本地机器,然后用记事本打开,检查哪个线程有大量重复,然后结合业务排除。(例如,如果堆栈的60%是由其中一个类的方法引起的,则该方法可能会阻塞。)
java查看线程状态 java线程池释放线程 java创建一个线程
版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。