idea占用cpu过高_排查cpu负载过高,还是java原生的这套组合拳好使

之前有点迷恋arthas,它很好的帮我解决了复杂接口耗时问题。再加上官网上介绍,一度我认为arthas是万能的。

但是排查了几次cpu过高的case,最终冷静下来了。

我的结论是排查CPU过高的场景,arthas其实并不擅长。

  • 首先cpu过高的场景,arthas可能都启动不起来。
  • 其次就算起来起来,找出的cpu过高的线程,大概率是arthas本身。
  • 最后每次打印的线程CPU占比变化很大,几乎没有实际指导意义。

最终我们还是采用java最原生的方式,排查CPU过高的问题。如下图CPU负载1257%

045f8993f844751c0b1bc55e18c37c5a.png

排查步骤

第一步:查消耗cpu最高的进程PID。

第二步:根据PID查出消耗CPU最高的线程。

2cfa6ad83a368bd146d4544738e63485.png

第三步:根据线程号查出对应的java线程,进行处理。

死循环代码:

public class TestCpu {public static void main(String[] args) {int random = 0;while (true){
random = random * 100;
}
}
}

(1)查消耗CPU最高的进程PID

执行命令执行top -c ,显示进程运行信息列表。按下P,进程按照cpu使用率排序

如下图所示,进程PID为 412的进程耗费CPU最高

3de390dd4fae329a273b020c93b04f25.png

(2)根据PID查询消耗CPU最高的线程号

执行命令 top-H -p 412 , 显示一个进程线程运行信息列表。按下P,进程按照CPU使用率排序

如下图索引,线程PID为 413的线程耗费CPU最高, 这是十进制数据,转成十六进制数据为19d

3de390dd4fae329a273b020c93b04f25.png

(3)根据线程号查java线程

执行命令,导出快照jstack -l 412 >412.jstack

然后执行grep命令,查看线程做0x19d了什么

cat 412.jstack |grep '19d' -C 8

998fab0f7c327034344f6f2975f2654b.png

简化步骤如下所示:

  • 步骤一:查看cpu占用高进程执行 top -c命令
  • 步骤二:查看cpu占用高线程top -H -p 412步骤三:CPU负载高线程ID,转化为十六进制。printf "%x" 413 (17880对应的十六进制是19d)
  • 步骤四:定位cpu占用线程jstack 412|grep 19d -A 30
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值