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命令获得)
        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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MAT工具使用说明.docx MAT(Memory Analyzer Tool)工具入门 一MAT简介 MAT(Memory Analyzer Tool),一个基于Eclipse的内存分析工具,是一个快速、功能丰富的JAVA heap分析工具,它可以帮助我们查找内存泄漏和减少内存消耗。使用内存分析工具从众多的对象中进行分析,快速的计算出在内存中对象的占用大小,看看是谁阻止了垃圾收集器的回收工作,并可以通过报表直观的查看到可能造成这种结果的对象。 二 使用MAT意义 当服务器应用占用了过多内存的时候,会遇到OutOfMemoryError。如何快速定位问题呢?Eclipse MAT的出现使这个问题变得非常简单。它能够离线分析dump的文件数据。 四 MAT操作流程 1先调用jdk的工具得到heap使用情况 我安装的是jdk1.6 C:/>java -version java version "1.6.0_11" Java(TM) SE Runtime Environment (build 1.6.0_11-b03) Java HotSpot(TM) Client VM (build 11.0-b16, mixed mode, sharing) 2调用jdk工具jps查看当前的java进程 C:/>jps 3504 Jps 3676 Bootstrap 3496 org.eclipse.equinox.launcher_1.0.201.R35x_v20090715.jar 3调用jmap工具得到信息 C:/>jmap -dump:format=b,file=heap.bin 3676 Dumping heap to C:/heap.bin ... Heap dump file created 这时,我们的C盘根目录,就生成了heap.bin文件。 4用eclipsefile---->open打开这个文件,首先是一个启动图: 这里可以选择查看 (1)内存泄露报表,自动检查可能存在内存泄露的对象,通过报表展示存活的对象以及为什么他们没有被垃圾收集; (2)对象报表,对可颖对象的分析,如字符串是否定义重了,空的collection、finalizer以及弱引用等。 我这里选择的是查看内存报表,以下是截的简略图: 通过报表展示,蛮清楚的,下面还有详细的说明,这里就没有帖图了,有兴趣的可以继续探究。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值