排查Java高CPU占用原因

开篇

 在简书看到一篇公众号讲如何排查CPU问题,想了想在日常工作中也偶尔遇到这样的问题,所以在网上搜了搜该方面的文章,特意拷贝了一篇文章作日后排查参考。

 整体来说是按照三步走:

  • 1、top命令发现占用cpu最多的进程PID
  • 2、ps命令查看该进程下占用cpu最多的线程tid并转换为16进制;
  • 3、jstack -l pid 保存进程堆栈并通过16进制的tid查找对应的代码块。


步骤

  • 1、top命令发现某个进程占用了100%的CPU
img_53af1437eb4c8de75ef01830cc1101be.png


  • 2、通过ps命令,进一步确定哪个进程出了问题
img_bb26d04efb60b2876d50eafaaecbea1d.png


  • 3、再查看线程占用CPU的列表
ps -mp PID(进程号)  -o THREAD,tid,time

说明:
-m Show threads after processes
img_ca7c8d956438265aed3f310223663acd.png


  • 4、找到占用CPU最高的线程,查看TID,将其转换为16进制格式
printf "%x\n" TID


  • 5、而后查看堆栈信息
jstack PID |grep 16进制TID -A 60
img_63a52188bb87ceb6bb49f92483af60a3.png


参考

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值