李成笔记网

专注域名、站长SEO知识分享与实战技巧

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

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

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

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

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

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

排查步骤

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

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


第三步:根据线程号查出对应的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最高

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

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

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


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

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

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

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




简化步骤如下所示:

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

发表评论:

控制面板
您好,欢迎到访网站!
  查看权限
网站分类
最新留言