java自帶的工具Jstack截取進(jìn)程中的堆棧信息
在Java軟件的使用過(guò)程中,有時(shí)會(huì)莫名的出現(xiàn)奇怪的問(wèn)題。而這些問(wèn)題常常無(wú)法使用日志信息定位,這時(shí)我們就需要通過(guò)查看進(jìn)程內(nèi)部線程的堆棧調(diào)用關(guān)系來(lái)分析問(wèn)題出在哪里。
舉個(gè)例子,當(dāng)我們?cè)谧瞿硞€(gè)操作時(shí),莫名的會(huì)彈出多個(gè)警告框,其中有些信息是正常的,有些則不是。對(duì)于這些錯(cuò)誤的警告信息,我們?cè)撊绾味ㄎ皇悄膫€(gè)位置的代碼出現(xiàn)了錯(cuò)誤彈出的框呢? 我們就需要在彈框以后,去查看軟件的各個(gè)線程,去查找究竟是哪個(gè)線程導(dǎo)致了該問(wèn)題。可是有時(shí)因?yàn)榄h(huán)境、時(shí)間等問(wèn)題,我們根本不能拿著IDE去調(diào)試, 只能通過(guò)工具軟件拍下內(nèi)存快照,然后分析內(nèi)存信息。
今天介紹一款常用的工具:Jstack
Jstack 是JDK自帶的工具,同時(shí)也是在JVM性能調(diào)優(yōu)種出鏡率非常高的一款軟件。所以掌握它是非常有必要的。
Jstack可以生成JVM當(dāng)前時(shí)間點(diǎn)的線程快照。
線程快照就是當(dāng)前JVM內(nèi)每一條線程正在執(zhí)行的方法堆棧的集合。而生成線程快照的主要原因:
1、通過(guò)線程快照定位線程出現(xiàn)長(zhǎng)時(shí)間停頓的原因,如線程間死鎖、死循環(huán)、請(qǐng)求外部資源導(dǎo)致的長(zhǎng)時(shí)間等待
2、通過(guò)線程快照分析當(dāng)前執(zhí)行方法的調(diào)用關(guān)系來(lái)確定異常信息的源頭。
它的使用非常簡(jiǎn)單:
(ps:前提是你已經(jīng)裝有帶有Jstack的JDK。同時(shí)最好已經(jīng)設(shè)置了環(huán)境變量。)
第一步: 通過(guò)Windows的任務(wù)管理器查看進(jìn)程的PID
這里簡(jiǎn)單說(shuō)下什么是PID:PID就是各進(jìn)程的身份標(biāo)識(shí),他是在軟件啟動(dòng)后,由操作系統(tǒng)分配的唯一的、用來(lái)標(biāo)識(shí)進(jìn)程身份的一個(gè)標(biāo)識(shí)
如圖
在進(jìn)程頁(yè)簽下,查看 > 選擇列
勾選PID 然后確定
切到應(yīng)用程序頁(yè)簽,選擇要快照內(nèi)存的程序。圖片中選擇的是Android Studio。點(diǎn)擊右鍵轉(zhuǎn)到進(jìn)程。
這里就查看到 Android Studio對(duì)應(yīng)的PID是 9952
第二步 打開(kāi)命令行,執(zhí)行Jstack程序
注意,如果沒(méi)有成功添加環(huán)境變量,那么這里只能在Jstack的路徑下執(zhí)行,否則操作系統(tǒng)無(wú)法識(shí)別。
如圖,這里一般有兩個(gè)運(yùn)行參數(shù),用來(lái)拍取內(nèi)存快照,
他們的含義如下:
-l long listings,會(huì)打印出額外的鎖信息,在發(fā)生死鎖時(shí)可以用jstack -l pid來(lái)觀察鎖持有情況
-m mixed mode,不僅會(huì)輸出Java堆棧信息,還會(huì)輸出C/C++堆棧信息(比如Native方法)
我們一般使用-l參數(shù)就可以滿足需要
格式如下 Jstack -l PID >> 123.txt
ps 這里注意下 >>是重定向的意思,也就是將拍取到的快照定向輸出到987.txt中。>> 的兩次最好保持空格
這樣我們就會(huì)在命令行路徑下生成一個(gè)987.txt文件,同時(shí)將內(nèi)存快照寫(xiě)入到這個(gè)文本中
如下圖:
相關(guān)文章
詳解SpringBoot restful api的單元測(cè)試
本篇文章主要介紹了詳解SpringBoot restful api的單元測(cè)試,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-09-09java編程調(diào)用存儲(chǔ)過(guò)程中得到新增記錄id號(hào)的實(shí)現(xiàn)方法
這篇文章主要介紹了java編程調(diào)用存儲(chǔ)過(guò)程中得到新增記錄id號(hào)的實(shí)現(xiàn)方法,涉及Java數(shù)據(jù)庫(kù)操作中存儲(chǔ)過(guò)程的相關(guān)使用技巧,需要的朋友可以參考下2015-10-10Java實(shí)現(xiàn)二維碼QRCode的編碼和解碼與示例解析
本文主要介紹Java實(shí)現(xiàn)二維碼QRCode的編碼和解碼,這里給大家一個(gè)小示例以便理解,有需要的小伙伴可以參考下2016-08-08Java中一個(gè)線程執(zhí)行死循環(huán)有什么后果
這篇文章主要為大家詳細(xì)介紹了Java中一個(gè)線程執(zhí)行死循環(huán)有什么后果,當(dāng)一個(gè)線程在執(zhí)行死循環(huán)時(shí)會(huì)影響另外一個(gè)線程嗎,下面為大家揭曉2016-05-05