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