JVM中常用堆疊追蹤內建指令

來源:互聯網
上載者:User

JVM中常用堆疊追蹤內建指令

在使用Java的程式中難免會遇上程式異常的現象,此時就可以使用JDK下的jstack和jmap來跟蹤觀察JVM中的記憶體堆棧資訊用以分析,不過注意的是如果是在Windows版本或者是開源版中一般都是沒有的,如果需要使用需要安裝相應的開發調試工具,下面就簡單的說一說:

jstack 一般而言之後跟著都是Java程式啟動並執行pid或者是相應的Java代碼檔案,如:jstack $pid,平時可以把相關的堆棧資訊再匯出到某一個檔案中正用以進一步觀察,如:jstack $pid > file.dump

jmap 同jstack的功能效果是差不多的,不過相比而言它會更為的強大一些,同樣它之後也是跟著Java程式啟動並執行pid,但是它還有一些參數選項:

預設是沒有帶這些參數選項的,僅能列印一些簡單的資訊
-heap    用於列印Java的堆棧的摘要資訊
-histo[:live]    用於列印堆棧的即時資訊,常用於堆棧的即時跟蹤
-clstats    用於列印Java中的類載入的資訊
-finalizerinfo    用於列印關於等待確定的對象的資訊
-dump:<dump-options>    把相關的堆棧資訊dump至二進位檔案中用於開發調試工具中使用,如:jmap -dump:format=b,file=Java_jmp.bin $pid
-F    該選項跟著-dump選項一起使用,表示在dump出的二進位檔案中不列印列印堆棧的即時資訊,但是其他的資訊都有列印
-J<flag>    將標誌傳給Java程式,即在做斷點

總之在Java的程式發生異常的時候利用其中相關的堆疊追蹤內建指令都能很好的排查其中的問題

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.