轉自:https://blog.csdn.net/jijianshuai/article/details/79128033
生成Java Heap Dump的幾種方式
Heap Dump 概述
Heap Dump的格式有很多種,而且不同的格式包含的信息也可能不一樣。但總的來說,Heap Dump一般都包含了一個堆中的Java Objects, Class等基本信息。同時,當你在執行一個轉儲操作時,往往會觸發一次GC,所以你轉儲得到的文件里包含的信息通常是有效的內容(包含比較少,或沒有垃圾對象了) 。
Heap Dump 包含的信息
- 所有的對象信息
對象的類信息、字段信息、原生值(int, long等)及引用值 - 所有的類信息
類加載器、類名、超類及靜態字段 - 垃圾回收的根對象
根對象是指那些可以直接被虛擬機觸及的對象 - 線程棧及局部變量
包含了轉儲時刻的線程調用棧信息和棧幀中的局部變量信息
Heap Dump 獲取方式
https://docs.oracle.com/javase/8/docs/technotes/guides/troubleshoot/tooldescr006.html#BABEHABG
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 文件
3.1 XX:+HeapDumpOnOutOfMemoryError
當OutOfMemoryError發生時自動生成 Heap Dump 文件。
這可是一個非常有用的參數,因為當你需要分析Java內存使用情況時,往往是在OOM(OutOfMemoryError)發生時。
3.2 -XX:+HeapDumpBeforeFullGC
當 JVM 執行 FullGC 前執行 dump。
3.3 -XX:+HeapDumpAfterFullGC
當 JVM 執行 FullGC 后執行 dump。
3.4 -XX:+HeapDumpOnCtrlBreak
交互式獲取dump。在控制台按下快捷鍵Ctrl + Break時,JVM就會轉存一下堆快照。
3.5 -XX:HeapDumpPath=d:\test.hprof
指定 dump 文件存儲路徑。
注意:JVM 生成 Heap Dump 的時候,虛擬機是暫停一切服務的。如果是線上系統執行 Heap Dump 時需要注意。
使用其它工具獲取dump文件
分析 Heap Dump 的工具都可以獲取 Heap Dump 文件。
比如:jdk 自帶的工具 jvisualvm。
其它工具:Eclipse memory analyzer(jmat)、JProfiler 等。