您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“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)
3.將tid轉(zhuǎn)換為16進(jìn)制的數(shù)字:printf “%x\n” tid
4.使用jstack命令,查詢(xún)線(xiàn)程信息,從而定位到具體線(xiàn)程和代碼:jstack pid | grep 7ccd -A 30
這樣,你就看到CPU這么高,是什么線(xiàn)程在搗亂了!
怎么樣,是不是覺(jué)得有點(diǎn)兒麻煩,沒(méi)有關(guān)系,我把這幾個(gè)步驟寫(xiě)成了一個(gè)腳本,直接使用就OK了。
以上是“JVM中占用的CPU偏高是怎么回事”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(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)容。