JVM问题排查——CPU过高

在这里插入图片描述


环境

JDK8

 

准备工作

先准备好一个自旋程序,模拟CPU过高:

public class CPUTest {

    public static void main(String[] args) {
        while(true){
            System.out.println("true");
        }
    }

}

针对两个问题,我们开始排查:

  1. 是哪个线程占用CPU过多
  2. 主要是哪部分代码执行时间过长
     

排查

使用top命令查看进程(默认按照CPU占比排序)
直接在控制台输入top回车即可
在这里插入图片描述
我们可以看到这里pid为29102的进程CPU占比最高,我们使用top -Hp 29102查看该进程下的线程(也是按CPU占比排序)
在这里插入图片描述也就是id为29103的线程有最高的CPU占比。
一般我们认为80%以上才算是CPU过高,但这里只是为了实验,所以姑且就分析一下这个39%占比的线程。
将29103转为16进制得到71af。在jstack分析时我们需要利用这个十六进制数。

接下来,使用jstack 29102来看一下这个java进程的线程快照。
在这里插入图片描述我们通过71af定位到想要找的线程(图中红框)。而事实上,如果我们在之前不使用top -Hp来查看线程的CPU占比,其实在上面这个线程快照中,也可以看到CPU的大致使用情况(黄框部分)。
找到这个线程后,看一下jstack为我们打印的线程信息。看蓝框部分,我们可以发现线程主要花费的时间在CPUTest的第五行代码(事实上线程快照也可能显示是其他代码行,我们需要多次jstack获取线程快照,如果多次看到同一行代码,也就意味着很可能是这行代码的执行时间比较长)
回到我们的源代码,第五行也就是:

System.out.println("true");

然后我们就可以针对这行代码,看看它前后的调用,或者它内部的逻辑等等,研究一下它大量消耗CPU的原因。

 


总结

排查CPU过高问题时,总体可分为如下几步:

  1. 使用top指令查看当前CPU消耗过高的进程是哪个(找出它的pid,例如是29102);
  2. 使用top -Hp 29102找到该进程中哪个线程消耗CPU最高(例如是29103);
  3. 计算29103为16进制数71af,利用jstack 29102查看线程快照;
  4. 在线程快照信息中找到编号为71af的线程,查看运行情况,定位到CPU消耗过高的代码行。

 
更多资料欢迎关注:
在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值