如何定位java程序中占用cpu最高的線程堆棧信息
找出占用cpu最高的線程堆棧信息
在java編碼中,有時(shí)會(huì)因?yàn)榇中膶?dǎo)致cpu占用較高的情況,為了避免影響程序的正常運(yùn)行,需要找到問題并解決。這里模擬一個(gè)cpu占用較高的場景,并嘗試定位到代碼行。
示例代碼如下:
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)的堆棧信息找出可能存在問題的代碼
如上圖,定位到第15行代碼,是由于while循環(huán)導(dǎo)致的。

到此這篇關(guān)于如何定位java程序中占用cpu最高的線程堆棧信息的文章就介紹到這了,更多相關(guān)定位java程序中占用cpu最高的線程堆棧信息內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java?中很好用的數(shù)據(jù)結(jié)構(gòu)EnumSet
這篇文章主要介紹了Java?中很好用的數(shù)據(jù)結(jié)構(gòu)EnumSet,EnumMap即屬于一個(gè)Map,下文圍繞主題展開詳細(xì)內(nèi)容,需要的小伙伴可以參考參考一下2022-05-05
SpringBoot?+?MyBatis-Plus構(gòu)建樹形結(jié)構(gòu)的幾種方式
在實(shí)際開發(fā)中,很多數(shù)據(jù)都是樹形結(jié)構(gòu),本文主要介紹了SpringBoot?+?MyBatis-Plus構(gòu)建樹形結(jié)構(gòu)的幾種方式,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-08-08
Java實(shí)現(xiàn)將PDF轉(zhuǎn)為PDF/A
通過將PDF格式轉(zhuǎn)換為PDF/A格式,可保護(hù)文檔布局、格式、字體、大小等不受更改,從而實(shí)現(xiàn)文檔安全保護(hù)的目的,同時(shí)又能保證文檔可讀、可訪問。本文將為大家介紹如何實(shí)現(xiàn)這一轉(zhuǎn)換,需要的可以參考一下2022-01-01
Java數(shù)據(jù)類型轉(zhuǎn)換實(shí)例解析
這篇文章主要介紹了Java數(shù)據(jù)類型轉(zhuǎn)換實(shí)例解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11
struts2.3.24+spring4.1.6+hibernate4.3.11+mysql5.5.25開發(fā)環(huán)境搭建圖文
這篇文章主要介紹了struts2.3.24+spring4.1.6+hibernate4.3.11+mysql5.5.25開發(fā)環(huán)境搭建圖文教程,感興趣的小伙伴們可以參考一下2016-06-06

