用Jstack跟踪Cpu占用率的Java线程

43 篇文章 0 订阅

以下方法在centOS下执行通过:
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,定位到线程后一切好办。 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值