日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > windows >内容正文

windows

java windows 取所有任务_Win下,通过Jstack截取Java进程中的堆栈信息

發(fā)布時間:2023/12/9 windows 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java windows 取所有任务_Win下,通过Jstack截取Java进程中的堆栈信息 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

在Java軟件的使用過程中,有時會莫名的出現(xiàn)奇怪的問題。而這些問題常常無法使用日志信息定位,這時我們就需要通過查看進(jìn)程內(nèi)部線程的堆棧調(diào)用關(guān)系來分析問題出在哪里。

舉個例子,當(dāng)我們在做某個操作時,莫名的會彈出多個警告框,其中有些信息是正常的,有些則不是。對于這些錯誤的警告信息,我們該如何定位是哪個位置的代碼出現(xiàn)了錯誤彈出的框呢? 我們就需要在彈框以后,去查看軟件的各個線程,去查找究竟是哪個線程導(dǎo)致了該問題。可是有時因為環(huán)境、時間等問題,我們根本不能拿著IDE去調(diào)試(你總不能拿著筆記本到客戶那里說,哥們我來調(diào)試下(防盜連接:本文首發(fā)自http://www.cnblogs.com/jilodream/ )吧), 只能通過工具軟件拍下內(nèi)存快照,然后分析內(nèi)存信息。

今天介紹一款常用的工具:Jstack

Jstack 是JDK自帶的工具,同時也是在JVM性能調(diào)優(yōu)種出鏡率非常高的一款軟件。所以掌握它是非常有必要的。

Jstack可以生成JVM當(dāng)前時間點(diǎn)的線程快照。

線程快照就是當(dāng)前JVM內(nèi)每一條線程正在執(zhí)行的方法堆棧的集合。而生成線程快照的主要原因:

1、通過線程快照定位線程出現(xiàn)長時間停頓的原因,如線程間死鎖、死循環(huán)、請求外部資源導(dǎo)致的長時間等待

2、通過線程快照分析當(dāng)前執(zhí)行方法的調(diào)用關(guān)系來確定異常信息的源頭。

它的使用非常簡單:

(ps:前提是你已經(jīng)裝有帶有Jstack的JDK。同時最好已經(jīng)設(shè)置了環(huán)境變量。)

第一步: 通過Windows的任務(wù)管理器查看進(jìn)程的PID

這里簡單說下什么是PID:PID就是各進(jìn)程的身份標(biāo)識,他是在軟件啟動后,由操作系統(tǒng)分配的唯一的、用來標(biāo)識進(jìn)程身份的一個標(biāo)識

如圖

在進(jìn)程頁簽下,查看 > 選擇列

勾選PID 然后確定

切到應(yīng)用程序頁簽,選擇要快照內(nèi)存的程序。圖片中選擇的是Android Studio。點(diǎn)擊右鍵轉(zhuǎn)到進(jìn)程。

這里就查看到 Android Studio對應(yīng)的PID是9952

第二步 打開命令行,執(zhí)行Jstack程序

注意,如果沒有成功添加環(huán)境變量,那么這里只能在Jstack的路徑下執(zhí)行,否則操作系統(tǒng)無法識別。

如圖,這里一般有兩個運(yùn)行參數(shù),用來拍取內(nèi)存快照,

他們的含義如下:

-l long listings,會打印出額(防盜連接:本文首發(fā)自http://www.cnblogs.com/jilodream/ )外的鎖信息,在發(fā)生死鎖時可以用jstack -l pid來觀察鎖持有情況

-m mixed mode,不僅會輸出Java堆棧信息,還會輸出C/C++堆棧信息(比如Native方法)

我們一般使用-l參數(shù)就可以滿足需要

格式如下 Jstack -l PID >> 123.txt

ps 這里注意下 >>是重定向的意思,也就是將拍取到的快照定向輸出到987.txt中。>> 的兩次最好保持空格

這樣我們就會在命令行路徑下生成一個987.txt文件,同時將內(nèi)存快照寫入到這個文本中

如下圖:

總結(jié)

以上是生活随笔為你收集整理的java windows 取所有任务_Win下,通过Jstack截取Java进程中的堆栈信息的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。