溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

JVM中占用的CPU偏高是怎么回事

發(fā)布時(shí)間:2022-03-30 14:44:42 來(lái)源:億速云 閱讀:776 作者:小新 欄目:編程語(yǔ)言

這篇文章主要為大家展示了“JVM中占用的CPU偏高是怎么回事”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“JVM中占用的CPU偏高是怎么回事”這篇文章吧。

在開(kāi)發(fā)過(guò)程中,有時(shí)候我們發(fā)現(xiàn)JVM占用的CPU居高不下,跟我們的預(yù)期不符,這時(shí),CPU在做什么呢?是什么線(xiàn)程讓CPU如此忙碌呢?我們通過(guò)如下幾步,可以查看CPU在執(zhí)行什么線(xiàn)程。

1.查找jvm進(jìn)程ID: jps -lv 或者 ps aux | grep java

2.根據(jù)pid,查找占用cpu較高的線(xiàn)程:ps -mp pid  -o THREAD,tid,time 如圖所示:找到占用cpu最高的tid (可以使用sort命令排序:sort -k 3 -r -n)

JVM中占用的CPU偏高是怎么回事

JVM中占用的CPU偏高是怎么回事

3.將tid轉(zhuǎn)換為16進(jìn)制的數(shù)字:printf “%x\n” tid

JVM中占用的CPU偏高是怎么回事


4.使用jstack命令,查詢(xún)線(xiàn)程信息,從而定位到具體線(xiàn)程和代碼:jstack pid | grep 7ccd -A 30

JVM中占用的CPU偏高是怎么回事


這樣,你就看到CPU這么高,是什么線(xiàn)程在搗亂了!

怎么樣,是不是覺(jué)得有點(diǎn)兒麻煩,沒(méi)有關(guān)系,我把這幾個(gè)步驟寫(xiě)成了一個(gè)腳本,直接使用就OK了。

JVM中占用的CPU偏高是怎么回事

以上是“JVM中占用的CPU偏高是怎么回事”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI