生成jvm快照文件


原文:https://blog.csdn.net/jijianshuai/article/details/79128033   

 -Xmx20m -Xms5m -XX:HeapDumpOnOutofMemoryError -XX:HeapDumpPath=d:/a.dump
分配了20M最大空間 ,啟動 最小空間5M , 發生了 內存溢出錯誤 dump路徑為a.dump

Heap Dump 概述
  Heap Dump 是 Java進程所使用的內存情況在某一時間的一次快照。以文件的形式持久化到磁盤中。
Heap Dump的格式有很多種,而且不同的格式包含的信息也可能不一樣。但總的來說,Heap Dump一般都包含了一個堆中的Java Objects, Class等基本信息。同時,當你在執行一個轉儲操作時,往往會觸發一次GC,所以你轉儲得到的文件里包含的信息通常是有效的內容(包含比較少,或沒有垃圾對象了) 。

Heap Dump 包含的信息
     >>.所有的對象信息
     >>.對象的類信息、字段信息、原生值(int, long等)及引用值
  >>.所有的類信息
  >>.類加載器、類名、超類及靜態字段
  >>.垃圾回收的根對象
  >>.根對象是指那些可以直接被虛擬機觸及的對象
  >>.線程棧及局部變量
  >>.包含了轉儲時刻的線程調用棧信息和棧幀中的局部變量信息
Heap Dump 獲取方式
1. 使用 jmap 命令生成 dump 文件
      jmap -dump:live,format=b,file=d:\dump\heap.hprof <pid>

2. 使用 jcmd 命令生成 dump 文件
     jcmd <pid> GC.heap_dump d:\dump\heap.hprof

3. 使用 JVM 參數獲取 dump 文件
  1. -XX:+HeapDumpOnOutOfMemoryError
    當OutOfMemoryError發生時自動生成 Heap Dump 文件。

    這可是一個非常有用的參數,因為當你需要分析Java內存使用情況時,往往是在OOM(OutOfMemoryError)發生時。

  2. -XX:+HeapDumpBeforeFullGC
    當 JVM 執行 FullGC 前執行 dump。

  3. -XX:+HeapDumpAfterFullGC
    當 JVM 執行 FullGC 后執行 dump。

  4. -XX:+HeapDumpOnCtrlBreak
    交互式獲取dump。在控制台按下快捷鍵Ctrl + Break時,JVM就會轉存一下堆快照。

  5. -XX:HeapDumpPath=d:\test.hprof
    指定 dump 文件存儲路徑。

    注意:JVM 生成 Heap Dump 的時候,虛擬機是暫停一切服務的。如果是線上系統執行 Heap Dump 時需要注意。

4. 使用其它工具獲取dump文件
分析 Heap Dump 的工具都可以獲取 Heap Dump 文件。
比如:jdk 自帶的工具 jvisualvm。
其它工具:Eclipse memory analyzer(jmat)、JProfiler 等。





免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM