如何定位java程序中占用cpu最高的線程堆棧信息
找出占用cpu最高的線程堆棧信息
在java編碼中,有時會因為粗心導(dǎo)致cpu占用較高的情況,為了避免影響程序的正常運行,需要找到問題并解決。這里模擬一個cpu占用較高的場景,并嘗試定位到代碼行。
示例代碼如下:
public class Math { public static final int initData = 666; public static User user = new User(); public int compute() { //一個方法對應(yīng)一塊棧幀內(nèi)存區(qū)域 int a = 1; int b = 2; int c = (a + b) * 10; return c; } public static void main(String[] args) { Math math = new Math(); while (true){ math.compute(); } } }
1,使用命令top -p ,顯示你的java進程的內(nèi)存情況,pid是你的java進程號,比如18963
2,按H,獲取每個線程的內(nèi)存情況
3,找到內(nèi)存和cpu占用最高的線程tid,比如18964
4,轉(zhuǎn)為十六進制得到 0x4a14,此為線程id的十六進制表示
5,執(zhí)行 jstack 18963|grep -A 10 4a14,得到線程堆棧信息中 4cd0 這個線程所在行的后面10行,從堆棧中可以發(fā)現(xiàn)導(dǎo)致cpu飆高的調(diào)用方法
6,查看對應(yīng)的堆棧信息找出可能存在問題的代碼
如上圖,定位到第15行代碼,是由于while循環(huán)導(dǎo)致的。
到此這篇關(guān)于如何定位java程序中占用cpu最高的線程堆棧信息的文章就介紹到這了,更多相關(guān)定位java程序中占用cpu最高的線程堆棧信息內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java實現(xiàn)Random隨機數(shù)生成雙色球號碼
使用Random類是Java中用于生成隨機數(shù)的標(biāo)準(zhǔn)類,本文主要介紹了Java實現(xiàn)Random隨機數(shù)生成雙色球號碼,具有一定的參考價值,感興趣的可以了解一下2023-11-11Spring框架通過工廠創(chuàng)建Bean的三種方式實現(xiàn)
這篇文章主要介紹了Spring框架通過工廠創(chuàng)建Bean的三種方式實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03SpringBoot實現(xiàn)發(fā)送短信的示例代碼
這篇文章主要介紹了SpringBoot實現(xiàn)發(fā)送短信的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04使用IDEA啟動項目遇見ClassNotFoundException的解決方案
這篇文章主要介紹了使用IDEA啟動項目遇見ClassNotFoundException的正確解決方案,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-06-06