Eclipse MAT解析headp dump,total size小于file size

1. 问题描述

  • 使用Eclipse MAT分析20GB+的heap dump文件

  • 最后解析出来dump size只有1GB+

2. 原因:heap dump中包含许多unreachable objects

  • Eclipse MAT的官方文档,《Basic Tutorial》章节,有对上图的Overview page做介绍

  • 针对total size小于file size的情况,有专门说明:

    If the total size of the dump is much smaller than the size of the file it is possible that the heap dump contained many 'garbage' objects which would be discarded at the next garbage collection. See the unreachable objects query to examine these 'garbage' objects.

  • 翻译过来就是:

    • heap dump包含许多垃圾对象,这些对象在下一次GC时可以回收,
    • 一般情况下,这些对象对于分析内存泄露来说是不重要的,MAT会在解析heap dump的过程中删除这些对象
  • MAT对unreachable objects出现原因的分析:

    • 如果heap dump是因为OOM产生的,JVM通常会进行GC操作以试图为新对象释放空间,这时heap dump文件中将不会包含unreachable objects
    • 如果并未执行GC操作,heap dump文件中就可能存在unreachable objects。
      • 例如,需要分配的空间非常大,即使进行GC操作也无法满足需求

      • 或者由于其他事件触发了heap dump(上述heap dump文件就是笔者通过jmap命令获得)

        bash 复制代码
        jmap -dump:format=b,file=file_name <pid>

3. 如何查看unreachable objects?

3.1 方法1:基于已有的解析,直接查看

3.1.1 Overview页面的link查看

  • 在Overview页面,通过 Unreachable Objects Histogram链接点击查看
  • 进入以后可以看到,unreachable objects有19GB左右,加上之前的1.4GB,与整个heap dump文件的大小是一致的

3.1.2 通过 Query Browser 查看

  • 通过工具栏,Query Browser → \rightarrow → Java Basics → \rightarrow → Unreachable Objects Histogram,查看unreachable objects

3.2 重新分析heap dump

  • 清理缓存:Window → \rightarrow → Heap Dump History → \rightarrow → 找到对应的heap dump文件 → \rightarrow → 右键,Delete Index Files
  • 允许MAT保留unreachable objects:Window → \rightarrow → Preferences → \rightarrow → Memory Analyzer → \rightarrow → 勾选'Keep unreachable objects' → \rightarrow → Apply and Close
  • 重新打开heap dump文件,这次MAT将不会丢弃unreachable objects
相关推荐
I'm Jie7 分钟前
告别重复编码!SpringBoot 字段变更(新旧值)日志工具类的规范化设计与优雅实现
java·spring boot·后端
哥谭居民000113 分钟前
需求分析,领域划分到选择套用业务模式到转化落地,两个基本案例
java·大数据·需求分析
Tao____18 分钟前
适合中小型项目的物联网平台
java·物联网·mqtt·开源·iot
小马爱打代码19 分钟前
Spring AI:多模态 AI 大模型
java·人工智能·spring
李贺梖梖24 分钟前
day07 方法、面向对象1
java
除了代码啥也不会27 分钟前
Java基于SSE流式输出实战
java·开发语言·交互
虹科网络安全30 分钟前
艾体宝干货 | Redis Java 开发系列#2 数据结构
java·数据结构·redis
sg_knight31 分钟前
SSE 技术实现前后端实时数据同步
java·前端·spring boot·spring·web·sse·数据同步
Slow菜鸟38 分钟前
Java项目基础架构(二)| 通用响应与异常
java·开发语言
毕设源码-钟学长39 分钟前
【开题答辩全过程】以 个人理财系统界面化设为例,包含答辩的问题和答案
java