如何在 Linux 上查找哪个线程cpu利用率最高?

如何在 Linux 上查找哪个线程cpu利用率最高?,第1张

可以用 top 命令看

1.找出cpu耗用厉害的进程pid, 终端执行top命令,然后按下shift+p (shift+m是找出消耗内存最高)查找出cpu利用最厉害的pid号

2.根据上面第一步拿到的pid号,top -H -p pid 。然后按下shift+p,查找出cpu利用率最厉害的线程号,比如top -H -p 1328

3.将获取到的线程号转换成16进制,去百度转换一下就行

4.使用jstack工具将进程信息打印输出,jstack pid号 >/tmp/t.dat,比如jstack 31365 >/tmp/t.dat

5.编辑/tmp/t.dat文件,查找线程号对应的信息

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,定位到线程后一切好办。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://www.outofmemory.cn/yw/8977716.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-23
下一篇 2023-04-23

发表评论

登录后才能评论

评论列表(0条)

保存