Java的jstack命令使用示例詳解
jstack命令簡介
jstack(Java Virtual Machine Stack Trace)是JDK提供的一個可以生成Java虛擬機當(dāng)前時刻的線程快照信息的命令行工具。線程快照一般被稱為threaddump或者javacore文件,是當(dāng)前Java虛擬機中每個線程正在執(zhí)行的Java線程、虛擬機內(nèi)部線程和可選的本地方法堆棧幀的集合。對于每個方法棧幀,將會顯示完整的類名、方法名、字節(jié)碼索引(bytecode index,BCI)和行號。生成的線程快照可以用于定位線程出現(xiàn)長時間停頓的原因,比如:線程間死鎖、死循環(huán)、請求外部資源被長時間掛起等等。
jstack命令參數(shù)
命令語法:
jstack [options] pid
命令參數(shù)說明:
option:jstack命令的可選參數(shù)。如果沒有指定這個參數(shù),jstack命令會顯示Java虛擬機當(dāng)前時刻的線程快照信息,如下圖:

pid:要打印配置信息的Java虛擬機的進程ID。
想要要獲取運行的Java虛擬機進程的列表,可以使用ps命令(Linux系統(tǒng)中)或tasklist命令(Windows系統(tǒng)中),如果Java虛擬機進程沒有在單獨的docker實例中運行,可以使用jps命令。
option都有哪些參數(shù)呢?我們來看一下。
-F參數(shù)
如果Java虛擬機進程由于進程掛起而沒有任何響應(yīng),那么可以使用-F參數(shù)(僅在Oracle Solaris和Linux操作系統(tǒng)上游戲)強制顯示線程快照信息。
比如:

-l參數(shù)
如果使用-l參數(shù),除了方法棧幀以外,jstack命令還會顯示關(guān)于鎖的附加信息,比如屬于java.util.concurrent的ownablesynchronizers列表。
比如:

-m參數(shù)
如果使用-m參數(shù),jstack命令將顯示混合的棧幀信息,除了Java方法棧幀以外,還有本地方法棧幀。本地方法棧幀是C或C++編寫的虛擬機代碼或JNI/native代碼。
比如:

在顯示結(jié)果中,以星號為前綴的幀是Java方法棧幀,而不以星號為前綴的是本地方法棧幀。比如:

-h 和 -help
顯示jstack命令的幫助信息。
結(jié)尾
雖然jstack命令已經(jīng)推出很久并且使用頻率比較搞,但它仍然是一個“實驗性質(zhì)的,并且沒有技術(shù)支持的”(Experimental and Unsupported)工具,日后可能會被轉(zhuǎn)正,也有可能在某個JDK版本中無聲無息地消失。所以,且用且珍惜吧。
不過,我們還可以使用Thread.getAllStackTracesgetAll()方法,獲取Java虛擬機中所有線程的StackTraceElement對象,進而獲得所有線程棧幀信息。
到此這篇關(guān)于Java的jstack命令使用示例詳解的文章就介紹到這了,更多相關(guān)Java的jstack命令使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
關(guān)于實體類中Date屬性格式化@JsonFormat @DateTimeFormat
這篇文章主要介紹了關(guān)于實體類中Date屬性格式化@JsonFormat @DateTimeFormat問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-07-07
Java throw Exception實現(xiàn)異常轉(zhuǎn)換
這篇文章主要介紹了Java throw Exception實現(xiàn)異常轉(zhuǎn)換,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-04-04
springboot實現(xiàn)全局異常處理的方法(住家飯系統(tǒng))
住家飯系統(tǒng)將異常類型分為客戶端異常(ClientException),系統(tǒng)異常(ServiceException),遠程調(diào)用異常(RemoteException),本文給大家介紹springboot實現(xiàn)全局異常處理的方法,感興趣的朋友一起看看吧2025-05-05

