Memory Analyzer 使用

转载地址http://wensong.iteye.com/blog/1986449


MAT是一个eclipse的插件,上手起来比较快。它能够快速的分析dump文件,可以直观的看到各个对象在内存占用的量大小,以及类实例的数量,对象之间的引用关系,找出对象的GC Roots相关的信息,此外还能生成内存泄露报表,疑似泄露大对象的报表等等。

  • 安装MAT
  • 可以选择eclipse插件的方式安装
    • http://download.eclipse.org/mat/1.3/update-site/
  • 也可以选择单独MAT程序下载安装
    • http://www.eclipse.org/mat/downloads.php
  • 使用MAT查内存溢出
    • 生成dump
  • 生成dump文件,可以直接用 jmap -dump:format=b,file=xxx.bin ${pid}的方式
  • 也可以直接用MAT生成,File-》Acquire Heap Dump -》选择要dump的java进程-》finish就可以了
  • 生成完dump后,可以用MAT打开 dump(如果是MAT dump完后会自动进行解析),File-》Open Heap Dump 对dump文件进行解析,最终生成一个Overview视图,这个图是一个概要图,显示了一些统计信息,包括整个size大小,class数量,以及对象 的数量,同时还将生成一个大对象的top图,并线显示大对象占用内存的百分比。
    • 类似:size:2.2MB Classes:3.3k Objects:50.1k ClassLoader:84 Unreachable Objects Histogram
    • 找出溢出源
      • Histogram视图(截图里柱子那个,边上的是Dominator Tree ):列出每個class产生了多少個实例,以及占有多大内存,所占百分比
        • 可以很容易找出站内存最多的几个类,根据Retained Heap排序,找出前几个。
        • 可以分不同的维度来查看类的Histogram视图,Group by class、Group by superclass、Group by class  loader、Group by package
        • 只要有溢出,时间久了,溢出类的实例数量或者其占有的内存会越来越多,排名也就越来越前,通过多次对比不同时间点下的Histogram图对比就能很容易把溢出类找出来。


        •  
        • Dominator Tree(支配树):列出每个对象(Object instance)与其引用关系的树状结构,还包含了占有多大内存,所占百分比
  • 可以很容易的找出占用内存最多的几个对象,根据Percentage(百分比)来排序。
  • 可以分不同维度来查看对象的Dominator Tree视图,Group by class、Group by class  loader、Group by package
  • 和Histogram类似,时间久了,通过多次对比也可以把溢出对象找出来,Dominator Tree和Histogram的区别是站的角度不一样,Histogram是站在类的角度上去看,Dominator Tree是站的对象实例的角度上看,Dominator Tree可以更方便的看出其引用关系。


  •  
    • 定位溢出的原因
      • 通过Path to GC Roots或者Merge Shortest Paths to GC Roots


      •  
  • 通 过Histogram视图或者Dominator Tree视图,找到疑似溢出的对象或者类后,选择Path to GC Roots或者Merge Shortest Paths to GC Roots,这里有很多过滤选项,一般来讲可以选择exclude all plantom/weak/soft etc. references。这样就排除了虚引用、弱引用、以及软引用,剩下的就是强引用。从GC上说,除了强引用外,其他的引用在JVM需要的情况下是都可以 被GC掉的,如果一个对象始终无法被GC,就是因为强引用的存在,从而导致在GC的过程中一直得不到回收,因此就内存溢出了。
  • 接下来就需要直接定位具体的代码,看看如何释放这些不该存在的对象,比如是否被cache住了,还是其他什么原因。
  • 找到原因,清理干净后,再对照之前的操作,看看对象是否还再持续增长,如果不在,那就说明这个溢出点被成功的堵住了。
  • 最后用jstat跟踪一段时间,看看Old和Perm区的内存是否最终稳定在一个范围内,如果长时间稳定在一个范围,那溢出的问题就解决了,如果还再继续增长,那继续用上述方法,看看是否存在其他代码的溢出点,继续找出,将其堵住。


  •  

     
    • 此外通过list objects或show objects by class也可以达到类似的效果,不过没看GC Roots的方式直观,这里就不细说了。
      • list objects -- with outgoing references : 查看这个对象持有的外部对象引用。
      • list objects -- with incoming references : 查看这个对象被哪些外部对象引用。
      • show objects by class  --  with outgoing references :查看这个对象类型持有的外部对象引用
      • show objects by class  --  with incoming references :查看这个对象类型被哪些外部对象引用 

Eclipse Memory Analyzer(简称MAT)是一款Java堆内存分析器,可以帮助开发人员找出Java应用程序中的内存泄漏和性能问题。以下是使用MAT的步骤: 1. 下载并安装Eclipse MAT插件:MAT是一个Eclipse插件,因此需要先安装Eclipse。然后在Eclipse中打开“Help”菜单,选择“Eclipse Marketplace”,搜索“Memory Analyzer”,安装“Memory Analyzer (MAT)”插件。 2. 导出Java堆转储文件:在Java应用程序出现内存问题时,可以使用Java虚拟机提供的命令生成Java堆转储文件(.hprof文件)。例如,可以使用以下命令生成Java堆转储文件: ``` jmap -dump:format=b,file=heapdump.hprof <pid> ``` 其中,<pid>是Java应用程序的进程ID。 3. 打开Java堆转储文件:在Eclipse中,选择“File”菜单,选择“Open Heap Dump”,并选择生成的Java堆转储文件。 4. 分析Java堆转储文件:在MAT中,可以使用各种工具和视图来分析Java堆转储文件,例如: - “Histogram”视图:显示Java堆中各个对象的数量和占用内存大小。 - “Dominator Tree”视图:显示Java堆中对象之间的继承关系,并计算每个对象及其子对象占用的内存大小。 - “Leak Suspects”视图:检测可能存在内存泄漏的对象,例如无法回收的对象或静态变量引用的对象。 MAT还提供了一些分析工具和插件,例如: - “Path to GC Roots”工具:查找对象到Java堆根之间的引用。 - “Compare to Baseline”插件:比较两个Java堆转储文件之间的差异。 以上是使用MAT的基本步骤,使用MAT还需要一定的Java虚拟机和内存管理知识。熟练使用MAT可以帮助开发人员更好地解决Java应用程序中的内存问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值