欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java自帶的工具Jstack截取進程中的堆棧信息

 更新時間:2016年01月07日 08:43:56   作者:jilodream  
本文給大家記錄的是java自帶的工具Jstack截取進程中的堆棧信息的方法,非常的實用,有需要的小伙伴可以參考下。

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

  舉個例子,當我們在做某個操作時,莫名的會彈出多個警告框,其中有些信息是正常的,有些則不是。對于這些錯誤的警告信息,我們該如何定位是哪個位置的代碼出現(xiàn)了錯誤彈出的框呢? 我們就需要在彈框以后,去查看軟件的各個線程,去查找究竟是哪個線程導致了該問題??墒怯袝r因為環(huán)境、時間等問題,我們根本不能拿著IDE去調(diào)試, 只能通過工具軟件拍下內(nèi)存快照,然后分析內(nèi)存信息。

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

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

Jstack可以生成JVM當前時間點的線程快照。

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

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

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

它的使用非常簡單:

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

第一步: 通過Windows的任務管理器查看進程的PID

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

如圖

在進程頁簽下,查看 > 選擇列

勾選PID 然后確定

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

這里就查看到 Android Studio對應的PID是 9952

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

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

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

他們的含義如下:

-l long listings,會打印出額外的鎖信息,在發(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)存快照寫入到這個文本中

如下圖:

相關(guān)文章

  • Java之打印String對象的地址

    Java之打印String對象的地址

    這篇文章主要介紹了Java之打印String對象的地址,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • 詳解SpringBoot restful api的單元測試

    詳解SpringBoot restful api的單元測試

    本篇文章主要介紹了詳解SpringBoot restful api的單元測試,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • java編程調(diào)用存儲過程中得到新增記錄id號的實現(xiàn)方法

    java編程調(diào)用存儲過程中得到新增記錄id號的實現(xiàn)方法

    這篇文章主要介紹了java編程調(diào)用存儲過程中得到新增記錄id號的實現(xiàn)方法,涉及Java數(shù)據(jù)庫操作中存儲過程的相關(guān)使用技巧,需要的朋友可以參考下
    2015-10-10
  • Java實現(xiàn)二維碼QRCode的編碼和解碼與示例解析

    Java實現(xiàn)二維碼QRCode的編碼和解碼與示例解析

    本文主要介紹Java實現(xiàn)二維碼QRCode的編碼和解碼,這里給大家一個小示例以便理解,有需要的小伙伴可以參考下
    2016-08-08
  • 深入JVM剖析Java的線程堆棧

    深入JVM剖析Java的線程堆棧

    這篇文章主要介紹了深入JVM剖析Java的線程堆棧,Java中的堆內(nèi)存和堆棧原理的應用等知識是深入學習Java的重點,需要的朋友可以參考下
    2015-07-07
  • Java中一個線程執(zhí)行死循環(huán)有什么后果

    Java中一個線程執(zhí)行死循環(huán)有什么后果

    這篇文章主要為大家詳細介紹了Java中一個線程執(zhí)行死循環(huán)有什么后果,當一個線程在執(zhí)行死循環(huán)時會影響另外一個線程嗎,下面為大家揭曉
    2016-05-05
  • 深入理解Spring Cloud Zuul過濾器

    深入理解Spring Cloud Zuul過濾器

    這篇文章主要給大家介紹了關(guān)于Spring Cloud Zuul過濾器的相關(guān)資料,通過閱讀本文您將了解:Zuul過濾器類型與請求生命周期、如何編寫Zuul過濾器、如何禁用Zuul過濾器和Spring Cloud為Zuul編寫的過濾器及其功能,需要的朋友可以參考下。
    2017-02-02
  • Windows10安裝IDEA 2020.1.2的方法步驟

    Windows10安裝IDEA 2020.1.2的方法步驟

    這篇文章主要介紹了Windows10安裝IDEA 2020.1.2的方法步驟,文中通過圖文介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-08-08
  • SpringBoot使用Captcha生成驗證碼

    SpringBoot使用Captcha生成驗證碼

    這篇文章主要介紹了SpringBoot如何使用Captcha生成驗證碼,幫助大家更好的理解和學習使用SpringBoot,感興趣的朋友可以了解下
    2021-04-04
  • Java防止短信盜刷和轟炸的解決方案

    Java防止短信盜刷和轟炸的解決方案

    短信盜刷和短信轟炸是項目開發(fā)中必須要解決的問題之一,它的優(yōu)先級不亞于 SQL 注入的問題,今天我們就來看下,如何防止這個問題,需要的朋友可以參考下
    2024-02-02

最新評論