溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

jstack和線程dump實例解析

發布時間:2020-08-21 17:49:09 來源:腳本之家 閱讀:174 作者:一人淺醉- 欄目:編程語言

jstack定義:

jstack是Java虛擬機自帶的一種堆棧跟蹤工具。

基本介紹:

jstack用于生成java虛擬機當前時刻的線程快照。線程快照是當前java虛擬機內每一條線程正在執行的方法堆棧的集合,生成線程快照的主要目的是定位線程出現長時間停頓的原因,如線程間死鎖、死循環、請求外部資源導致的長時間等待等。

線程出現停頓的時候通過jstack來查看各個線程的調用堆棧,就可以知道沒有響應的線程到底在后臺做什么事情,或者等待什么資源。

命令格式:

jstack [ option ] pid

基本參數:

-F 當'jstack [-l] pid'沒有相應的時候強制打印棧信息

-l 長列表. 打印關于鎖的附加信息,例如屬于java.util.concurrent的ownable synchronizers列表.

-m 打印java和native c/c++框架的所有棧信息. -h | -help打印幫助信息

pid 需要被打印配置信息的java進程id,可以用jps工具查詢

案例

C:\Users\Administrator>jstack 5516
Full thread dump Java HotSpot(TM) 64-Bit Server VM (24.79-b02 mixed mode):
 
"DestroyJavaVM" prio=6 tid=0x000000000027d800 nid=0x1bb0 waiting on condition [0
x0000000000000000]
 java.lang.Thread.State: RUNNABLE
 
"Thread-1" prio=6 tid=0x000000000cb13800 nid=0x19ac waiting for monitor entry [0
x000000000d67f000]
 java.lang.Thread.State: BLOCKED (on object monitor)
 at thread.DeadLockDemo$2.run(DeadLockDemo.java:35)
 - waiting to lock <0x00000007d5a9be88> (a java.lang.String)
 - locked <0x00000007d5a9beb8> (a java.lang.String)
 at java.lang.Thread.run(Unknown Source)
 
"Thread-0" prio=6 tid=0x000000000cb0e800 nid=0x6bc waiting for monitor entry [0x
000000000d48f000]
 java.lang.Thread.State: BLOCKED (on object monitor)
 at thread.DeadLockDemo$1.run(DeadLockDemo.java:21)
 - waiting to lock <0x00000007d5a9beb8> (a java.lang.String)
 - locked <0x00000007d5a9be88> (a java.lang.String)
 at java.lang.Thread.run(Unknown Source)

這里運行了一段死鎖code,導致程序中的兩個線程都在等待對方釋放鎖,造成程序死鎖。

從這段代碼中可以明確的看出是 DeadLockDemo.class 中的第35行,和21行出現了阻塞,然后就是要優化這個函數了。

PS : 在實際運行中,往往一次 dump的信息,還不足以確認問題。建議產生三次 dump信息,如果每次 dump都指向同一個問題,我們才確定問題的典型性。

總結

以上就是本文關于jstack和線程dump實例解析的全部內容,希望對大家有所幫助。感興趣的朋友可以繼續參閱本站其他相關專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女