首页 后端 正文

CPU使用率高问题排查(jstack)


1.编写代码

public class Demo {
    public static void main(String[] args) {
        System.err.println("测试开始");
        while(true){

        }
    }
}


编写一个死循环代码。

执行此代码

#编译
javac Demo.java
#执行
java Demo


注意:可能上面两条十分简单的java命令,就难倒了一大批人,毕竟咱们都用惯了idea等开发工具,已经忘记了基本的命令了。

  • 编译

CPU使用率高问题排查(jstack)  第1张

  • 执行

CPU使用率高问题排查(jstack)  第2张

好家伙,都执行报错了Error: Could not find or load main class Demo

然后一顿百度,大部分都说要注意package包名的问题,可是哥们这,都没有package的。

最后找到一篇文章是说,要注意classpath的问题,我这确实是这个问题导致的。

  • 处理的办法有两个:

    1.将classpath配置在环境变量中。

    2.执行java的命令时,带上classpath参数

那这里,咱们使用第2种方式:

java -cp /root/Demo Demo


CPU使用率高问题排查(jstack)  第3张

测试正常!!!^_^

注意:-cp是,-classpath的缩写

2.找到CPU占用率高的进程

我们可以观察到top查看cpu占用高的进程。

CPU使用率高问题排查(jstack)  第4张

找到cpu占用率为 100%的线程。

PID 为 7744

3. 导出执行堆栈

jstack 7744 >> java.txt

`7744` 为进程号


jstack 命令是JDK工具之一,使用该命令可以打印正在运行中 Java 进程的栈信息。

4. 查占用率高的线程

top -H -p 7744


CPU使用率高问题排查(jstack)  第5张

找到线程号 为 7745

5. 转换16进制

printf "%x\n" 7745

执行后 为 1e41


6. 在之前导出的堆栈文件查找

查找1e41

CPU使用率高问题排查(jstack)  第6张

"main" #1 prio=5 os_prio=0 tid=0x00007fd79c009000 nid=0x1e41 runnable [0x00007fd7a205d000]
   java.lang.Thread.State: RUNNABLE
    at Demo.main(Demo.java:11)


发现是我们的Demo第11行出了问题,这样找回源码,去掉死循环即可。

CPU使用率高问题排查(jstack)  第7张

好了,以上就是用jstackCPU使用率高问题的排查了!!!

今天就先到这里了,溜了溜了溜了!!!^_^

觉得有收获的,帮忙点个赞呗!!!

CPU使用率高问题排查(jstack)  第8张

原文:https://juejin.cn/post/7096007844972986375

打赏
海报

本文转载自互联网,旨在分享有价值的内容,文章如有侵权请联系删除,部分文章如未署名作者来源请联系我们及时备注,感谢您的支持。

转载请注明本文地址:https://www.shouxicto.com/article/3987.html

相关推荐

发布评论

ainiaobaibaibaibaobaobeishangbishibizuichiguachijingchongjingdahaqiandaliandangaodw_dogedw_erhadw_miaodw_tuzidw_xiongmaodw_zhutouganbeigeiliguiguolaiguzhanghahahahashoushihaixiuhanheixianhenghorse2huaixiaohuatonghuaxinhufenjiayoujiyankeaikeliankouzhaokukuloukunkuxiaolandelinileimuliwulxhainiolxhlikelxhqiuguanzhulxhtouxiaolxhwahahalxhzanningwennonuokpinganqianqiaoqinqinquantouruoshayanshengbingshiwangshuaishuijiaosikaostar0star2star3taikaixintanshoutianpingtouxiaotuwabiweifengweiquweiwuweixiaowenhaowoshouwuxiangjixianhuaxiaoerbuyuxiaokuxiaoxinxinxinxinsuixixixuyeyinxianyinyueyouhenghengyuebingyueliangyunzanzhajizhongguozanzhoumazhuakuangzuohenghengzuoyi
支付宝
微信
赞助本站