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

java自帶的工具Jstack截取進(jìn)程中的堆棧信息

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

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

  舉個(gè)例子,當(dāng)我們在做某個(gè)操作時(shí),莫名的會彈出多個(gè)警告框,其中有些信息是正常的,有些則不是。對于這些錯(cuò)誤的警告信息,我們該如何定位是哪個(gè)位置的代碼出現(xiàn)了錯(cuò)誤彈出的框呢? 我們就需要在彈框以后,去查看軟件的各個(gè)線程,去查找究竟是哪個(gè)線程導(dǎo)致了該問題??墒怯袝r(shí)因?yàn)榄h(huán)境、時(shí)間等問題,我們根本不能拿著IDE去調(diào)試, 只能通過工具軟件拍下內(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、通過線程快照定位線程出現(xiàn)長時(shí)間停頓的原因,如線程間死鎖、死循環(huán)、請求外部資源導(dǎo)致的長時(shí)間等待

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

它的使用非常簡單:

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

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

這里簡單說下什么是PID:PID就是各進(jìn)程的身份標(biāo)識,他是在軟件啟動(dòng)后,由操作系統(tǒng)分配的唯一的、用來標(biāo)識進(jìn)程身份的一個(gè)標(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)無法識別。

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

他們的含義如下:

-l long listings,會打印出額外的鎖信息,在發(fā)生死鎖時(shí)可以用jstack -l pid來觀察鎖持有情況

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

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

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

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

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

如下圖:

相關(guān)文章

  • JAVA NIO按行讀寫大文件出現(xiàn)中文亂碼問題的解決

    JAVA NIO按行讀寫大文件出現(xiàn)中文亂碼問題的解決

    這篇文章主要為大家詳細(xì)介紹了JAVA在使用NIO進(jìn)行按行讀寫大文件時(shí)出現(xiàn)中文亂碼問題是如何解決的,文中的示例代碼簡潔易懂,有需要的小伙伴可以參考一下
    2025-02-02
  • 基于SpringBoot啟動(dòng)類靜態(tài)資源路徑問題

    基于SpringBoot啟動(dòng)類靜態(tài)資源路徑問題

    這篇文章主要介紹了SpringBoot啟動(dòng)類靜態(tài)資源路徑問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • 如何解決springboot上傳文件路徑找不到的問題

    如何解決springboot上傳文件路徑找不到的問題

    這篇文章主要介紹了如何解決springboot上傳文件路徑找不到的問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2025-04-04
  • SpringBoot整合Servlet和Filter和Listener組件詳解

    SpringBoot整合Servlet和Filter和Listener組件詳解

    這篇文章主要介紹了SpringBoot整合Servlet和Filter和Listener組件詳解,在整合某報(bào)表插件時(shí)就需要使用Servlet,Spring Boot中對于整合這些基本的Web組件也提供了很好的支持,需要的朋友可以參考下
    2024-01-01
  • 深入了解SpringMVC初始化流程

    深入了解SpringMVC初始化流程

    框架源碼是我們?Coding?晉級中的必修課,SSM?應(yīng)該算是小伙伴們?nèi)粘=佑|最多的框架了,這其中?SpringMVC?初始化流程相對來說要簡單一些,因此本文就先來和大家分析一下?SpringMVC?初始化流程
    2022-07-07
  • JavaWeb Spring注解Annotation深入學(xué)習(xí)

    JavaWeb Spring注解Annotation深入學(xué)習(xí)

    這篇文章主要為大家詳細(xì)介紹了JavaWeb Spring注解Annotation,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-09-09
  • Springboot+MyBatis進(jìn)行日志輸出參考示例

    Springboot+MyBatis進(jìn)行日志輸出參考示例

    這篇文章主要給大家介紹了關(guān)于Springboot+MyBatis進(jìn)行日志輸出的相關(guān)資料,在項(xiàng)目開發(fā)過程中,日志是必不可少的,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-08-08
  • JDK1.8新特性Stream流式操作的具體使用

    JDK1.8新特性Stream流式操作的具體使用

    這篇文章主要介紹了JDK1.8新特性Stream流式操作的具體使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • SpringBoot中@ConfigurationProperties注解的使用與源碼詳解

    SpringBoot中@ConfigurationProperties注解的使用與源碼詳解

    這篇文章主要介紹了SpringBoot中@ConfigurationProperties注解的使用與源碼詳解,@ConfigurationProperties注解用于自動(dòng)配置綁定,可以將application.properties配置中的值注入到bean對象上,需要的朋友可以參考下
    2023-11-11
  • SpringMVC多個(gè)文件上傳及上傳后立即顯示圖片功能

    SpringMVC多個(gè)文件上傳及上傳后立即顯示圖片功能

    這篇文章主要介紹了SpringMVC多個(gè)文件上傳及上傳后立即顯示圖片功能,非常不錯(cuò),具有參考借鑒價(jià)值功能,需要的朋友可以參考下
    2017-10-10

最新評論