Java程序占用 CPU 過高排查

模擬占用CPU高的代碼

 public class TestCpu{
    public static void main(String[] args) {
        cpu();
    }

    private static void cpu() {
        int i = 0;
        while (true){
            i++;
        }
    }
}

//編譯
[root@rabbit-102 ~]# javac TestCpu.java
//運行
[root@rabbit-102 ~]# java TestCpu &

排查步驟

第一步:使用top命令,查看占用CPU高的pid(進程)

  • 下圖可以看到,當前占用CPU最高的是69200進程,且是使用java命令運行
    image.png

第二步:找到pid中,占用CPU高的tid(線程id)

  • 使用top -Hp <pid>命令,查看pid中哪個tid占用CPU高

// 當前示例中的pid=69200,從下圖中可以看出,是69201這個tid占用CPU高
[root@rabbit-102 ~]# top -Hp 69200

image.png

  • 或使用 ps H -eo pid,tid,%cpu | grep <pid> 命令也可以查看

[root@rabbit-102 ~]# ps H -eo pid,tid,%cpu | grep 69200


image.png

第三步:將10進制線程id,轉(zhuǎn)16進制

  • 直接使用 printf "%x\n" <tid> 命令即可

[root@rabbit-102 ~]# printf "%x\n" 69201
10e51
[root@rabbit-102 ~]#

第四步:使用jstack來查看java堆棧信息

*使用 jstack <pid> | grep <十六進制的tid> 命令來查看

// -A10 表示顯示10行
[root@rabbit-102 ~]# jstack 69200 | grep 10e51 -A10


image.png
  • 還可以使用 jstack <pid> > <filename> 將堆棧信息保存到文件中,然后自行分析

// 保存堆棧信息到t.log中
[root@rabbit-102 ~]# jstack 69200 > t.log
//直接在t.log中篩選出10e51線程id的信息
[root@rabbit-102 ~]# cat t.log | grep 10e51 -A10


image.png

參考

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容