LINUX系统下查看JAVA的哪个线程占用CPU高

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LINUX系统下查看JAVA的哪个线程占用CPU高相关的知识,希望对你有一定的参考价值。

以下方法在LINUX下执行通过:
1.先定位占用cpu高的进程
top
2.使用以下命令
ps p 14766 -L -o pcpu,pid,tid,time,tname,stat,psr | sort -n -k1 -r
其中14766是刚才1中cpu占用率高的进程pid
3.2.4 32525 32537 01:58:41 ? Sl 6
0.8 32525 1771 00:43:12 ? Sl 0
0.8 32525 1769 00:39:46 ? Sl 0
0.7 32525 12324 00:33:36 ? Sl 0
0.5 32525 1772 00:27:50 ? Sl 0
0.5 32525 1768 00:25:45 ? Sl 0
0.4 32525 30760 00:19:13 ? Sl 0
0.4 32525 1773 00:22:36 ? Sl 0
0.4 32525 1770 00:20:25 ? Sl 0
0.3 32525 32385 00:00:10 ? Sl 0
0.1 32525 31668 00:00:03 ? Sl 0
0.1 32525 31667 00:00:03 ? Sl 0
0.1 32525 1790 00:07:10 ? Sl 1
其中第3个结果就是此进程中有问题的线程nid
4.通过jstack命令dump出堆栈
"AppController_ThreadPool_L2_Pool Thread" daemon prio=10 tid=0x0000000051c2b000 nid=0x7bb3 in Object.wait() [0x000000005e3c5000]
java.lang.Thread.State: TIMED_WAITING (on object monitor)
at java.lang.Object.wait(Native Method)
at org.company.threadpool.ThreadPoolImpl$PoolThread.run(ThreadPoolImpl.java:142)
- locked <0x00002aaca30341a8> (a org.company.threadpool.ThreadPoolImpl$PoolThread)
其中的nid就是线程的编码,只不过是经过了16进制的转换。
即十进制的31776对应的十六进制)0x7bb3,定位到线程后一切好办。
参考技术A f据官方军阀割据法国警方国家

linux下查找java进程占用CPU过高原因

linux下查找java进程占用CPU过高原因

1. 查找进程

top查看进程占用资源情况

明显看出java的两个进程22714,12406占用过高cpu.

 

2.查找线程

使用top -H -p <pid>查看线程占用情况

 

3.查找java的堆栈信息

将线程id转换成十六进制

#printf %x 15664

#3d30

 

然后再使用jstack查询线程的堆栈信息

语法:jstack <pid> | grep -a 线程id(十六进制)

 

jstack <pid> | grep -a 3d30

 

这样就找出了有问题的代码了。

 

剩下的就是分析原因和修改代码了。


本文出自 “32氪” 博客,请务必保留此出处http://10672221.blog.51cto.com/10662221/1983809

以上是关于LINUX系统下查看JAVA的哪个线程占用CPU高的主要内容,如果未能解决你的问题,请参考以下文章

linux怎么查看哪个进程占用cpu

查看Java哪个线程占用CPU资源

linux下查找java进程占用CPU过高原因

linux下查找java进程占用CPU过高原因

linux怎么查看线程cpu

Linux 某个进程中占用CPU高的线程