這篇文章主要為大家展示了“JVM中占用的CPU偏高是怎么回事”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“JVM中占用的CPU偏高是怎么回事”這篇文章吧。
在開發過程中,有時候我們發現JVM占用的CPU居高不下,跟我們的預期不符,這時,CPU在做什么呢?是什么線程讓CPU如此忙碌呢?我們通過如下幾步,可以查看CPU在執行什么線程。
1.查找jvm進程ID: jps -lv 或者 ps aux | grep java
2.根據pid,查找占用cpu較高的線程:ps -mp pid -o THREAD,tid,time 如圖所示:找到占用cpu最高的tid (可以使用sort命令排序:sort -k 3 -r -n)
3.將tid轉換為16進制的數字:printf “%x\n” tid
4.使用jstack命令,查詢線程信息,從而定位到具體線程和代碼:jstack pid | grep 7ccd -A 30
這樣,你就看到CPU這么高,是什么線程在搗亂了!
怎么樣,是不是覺得有點兒麻煩,沒有關系,我把這幾個步驟寫成了一個腳本,直接使用就OK了。
以上是“JVM中占用的CPU偏高是怎么回事”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。