【JVM笔记】导出内存映像(dump)文件

什么是 dump 文件

一般来说,使用 jmap 指令生成 dump 文件的操作算得上是最常用的 jmap 命令之一,将堆中所有

存活对象导出至一个文件之中

Heap Dump 又叫做堆存储文件,指一个 Java 进程在某个时间点的内存快照。Heap Dump 在触发内存快照的时候会保存此刻的信息如下: ● All 0bjects Class, fields ,primitive values and references ● All Classes ClassLoader ,name , super class,static fields ● Garbage Collection Roots| objects defined to be reachable by the JVM ● Thread Stacks and Local Variables The call-stacks of threads at the moment of the snapshot ,and per- frameinformation about local objects 说明:

通常在写 Heap Dump 文件前会触发一次 Full GC,所以 heap dump 文件里保存的都是 Full GC 后留下的对象信息

手动导出

jmap -dump:format = b,file = <filename,hprof> <pid> jmap -dump:live,format = b,file = <filename,hprof> <pid>

由于 jmap 将访问堆中的所有对象,为了保证在此过程中不被应用线程干扰,jmap 需要借助安

全点机制,让所有线程停留在不改变堆中数据的状态。也就是说,由 jmap 导出的堆快照必定

是安全点位置的。这可能导致基于该堆快照的分析结果存在偏差 举个例子,假设在编译生成的机器码中,某些对象的生命周期在两个安全点之间,那么:live 选项将无法探知到这些对象 另外,如果某个线程长时间无法跑到安全点,jmap 将一直等 下去

在 OOM 时导出

当程序发生 OOM 退出系统时,一些瞬时信息都随着程序的终止而消失,而重现 OOM 问题往往比 较困难或者耗时。此时若能在 OOM 时,自动导出 dump 文件就显得非常迫切 这里介绍一种比较常用的取得堆快照文件的方法,即使用:

- Xx: +HeapDumpOnOutOfMemoryError:在程序发生 OOM 时,导出应用程序的当前堆快照 - XX:HeapDumpPath=<filename.hprof>:可以指定堆快照的保存位置

比如: -Xmx100m - XX: +HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=D: m. hprof

经验分享 程序员 微信小程序 职场和发展