原文: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 等。