Java 演示生產(chǎn)環(huán)境 cpu 飆高及排查思路

Java 演示生產(chǎn)環(huán)境 cpu 飆高及排查思路

環(huán)境信息

生產(chǎn)環(huán)境模擬服務(wù)器:阿里云 Centos7

服務(wù)器安裝 jdk 版本:1.8.0

cpu 飆高代碼 CpuHighDemo

模擬 cpu 飆高,死循環(huán)即可:

import java.util.UUID;

public class CpuHighDemo {

    public static void main(String[] args) {
        while (true) {
            System.out.printf("%s: %s\n", Thread.currentThread().getName(), UUID.randomUUID().toString().substring(0, 8));
        }
    }

}

將上述代碼放到阿里云 Centos7 服務(wù)器上,編譯:

javac CpuHighDemo.java

示意圖如下:

為了方便當(dāng)前端口執(zhí)行排查操作,故后臺(tái)運(yùn)行 CpuHighDemo

nohup java CpuHighDemo &

示意圖如下:

我們看一下 nohup.out 里的輸出內(nèi)容:

說明程序在不停打印

排查思路及步驟

1. top 命令找出 cpu 占比最高的進(jìn)程

top

可看出當(dāng)前 cpu 占比最高的是 PID = 14073 的 java 進(jìn)程

2. ps -ef 或者 jps 進(jìn)一步定位進(jìn)程信息

ps -ef | grep -v grep | grep PID

3. 定位到進(jìn)程內(nèi)具體線程

# PID 為上一步定位到的進(jìn)程編號(hào)
ps -mp PID -o THREAD,tid,time

得到 PID = 14073 進(jìn)程內(nèi) cpu 占比最高的線程為 tid = 14074 的線程

4. 將定位到的線程 tid 轉(zhuǎn)換為 16 進(jìn)制

# 將十進(jìn)制的 tid 轉(zhuǎn)換為 16 進(jìn)制輸出(默認(rèn)是大寫英文模式)
# 該方法可將任意十進(jìn)制數(shù) tid 轉(zhuǎn)換為任意 obase 的 value 進(jìn)制的數(shù)值
echo "obase=16;tid" | bc

# 將十進(jìn)制的 tid 轉(zhuǎn)換為 16 進(jìn)制英文小寫格式輸出(方法 1)
echo "obase=16;tid" | bc | awk '{print tolower($0)}'

# 將十進(jìn)制的 tid 轉(zhuǎn)換為 16 進(jìn)制英文小寫格式輸出(方法 2)<推薦方法>
printf "%x\n" tid

5. 查看定位到的線程堆棧信息

# 查看定位到的線程堆棧信息,注意 tid 需要十六進(jìn)制形式
jstack PID | grep -i tid(十六進(jìn)制形式) -A60

已定位出報(bào)錯(cuò)的具體代碼位置

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

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

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