• 【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

  • 相关阅读:
    分享大数据培训班班型
    shell SNAT与DNAT
    JAVA班主任管理系统(源代码+论文)
    Idea插件 Sonar
    数据挖掘知识随笔
    分享 2022 年最受欢迎的黑科技工具(二)
    Vue3语法糖setup(二)
    无涯教程-JavaScript - ASINH函数
    关于前端开发中导入导出
    【微服务|OpenFeign】openfeign的超时时间
  • 原文地址:https://blog.csdn.net/lijibai_/article/details/126502009