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


    目录

    什么是 dump 文件

    手动导出

    在 OOM 时导出


    什么是 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 =

    jmap -dump:live,format = b,file =

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

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

    是安全点位置的。这可能导致基于该堆快照的分析结果存在偏差

    举个例子,假设在编译生成的机器码中,某些对象的生命周期在两个安全点之间,那么:live 选项将无法探知到这些对象

    另外,如果某个线程长时间无法跑到安全点,jmap 将一直等 下去

    OOM 时导出

    当程序发生 OOM 退出系统时,一些瞬时信息都随着程序的终止而消失,而重现 OOM 问题往往比

    较困难或者耗时。此时若能在 OOM 时,自动导出 dump 文件就显得非常迫切

    这里介绍一种比较常用的取得堆快照文件的方法,即使用:

    - Xx: +HeapDumpOnOutOfMemoryError:在程序发生 OOM 时,导出应用程序的当前堆快照

    - XX:HeapDumpPath=:可以指定堆快照的保存位置

    比如:

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

  • 相关阅读:
    Nacos Jaspyt配置加密设置
    2022年编程语言排名,官方数据来了,让人大开眼界
    Hbase
    用Python抓取京东商品评论
    Redis入门概述
    DDoS攻击类型
    新威凌将开启申购:2022年第三季度业绩下滑,陈志强为董事长
    Java:在Java 8及更高版本中使用Java流
    如何在虚拟机的Ubuntu22.04中设置静态IP地址
    typescript学习笔记
  • 原文地址:https://blog.csdn.net/lijibai_/article/details/126502009