内存分析工具MAT的使用

  • 格式:doc
  • 大小:1.40 MB
  • 文档页数:17

下载文档原格式

  / 17
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

内存分析工具MAT的使用

一、MAT插件安装

MAT(Memory Analyzer Tool) 是基于heap dumps来进行分析的,它的分析速度比jhat快,分析结果是图形界面显示,比java内置jhat的可读性更高,通过Eclipse市场安装方法/步骤1

打开Eclipse - >help - > Eclipse Marketplace

2

点击install,等待下面的进度条加载完毕后,勾选全部,点击Next

3

同意协议后,点击Finish就开始安装MAT了

直接输入URL安装方法/步骤2

1.打开Eclipse - >help - > Install New Software

2.在work with输入图中下载地址,勾选Memory Analyzer for

Eclipse IDE选项

3.若没有勾选Memory Analyzer for Eclipse IDE选项,点击地址栏

旁边的Add,在location里输入以上地址,点击OK即可。

4.安装完成后提示重启Eclipse,重启后打开window - > open

perspective,看到Memory Analysis证明安装成功。

二、MAT的使用

案例一

问题

线上某一台机器出现异常.接口调用的rt达到了万级别..基本可以判断这个机器已经挂了.进而分析该机器一直在fgc.然后马上dump内存,进而进行分析(中间一些异常的gc日志没有截图).之前学习的jvm知识都是纯理论的,这次是实打实线上出现的问题.所以记录一下.

步骤

1 、先dump对应的堆,然后从线上发到自己本机

dump的命令是

jmap -dump:format=b,

2、调整eclipse的内存

具体的数值,需要看dump的文件大小.比如我的dump文件是1.3G,我就给了eclipse 2G的内存..据说有些dump文件有几十个G的大小,那么分析的机器也必须比这个大才行,否则eclipse本身就OOM了.

3、分析.

调整到 Memory Analysis 窗口,然后File->Open Heap Dump

然后选择dump的文件,然后MAT就自动会进行分析..分析完了,直接查

看Leak Suspects Report . MAT会自动帮你找内存泄露的疑凶.然后给你

点下面的Detail .可以看到最直观的类和所占用的大小

可以看到, IosPushClient 的直接引用是40byte 但是对应的间接引用达到了恐怖的420M 那么再点击该类,list obejcts .重点看间接引用占用的大的

可以看到这个LinkedHashMap中,有47528个1776byte的对象。

其实看到这里,就基本清楚了.这个是由于在push的时候把对应的push消息给保留住,然后造成一直堆积在内存中造成的。

解决办法:

在不修改对应的push底层实现的前提下,每次push了2W条消息就清理一次.后续有时间再修改底层逻辑吧.

案例二

1 内存泄漏的排查方法

Dalvik Debug Monitor Server (DDMS) 是ADT插件的一部分,其中有两项功能可用于内存检查:

· heap 查看堆的分配情况

· allocation tracker跟踪内存分配情况

DDMS 这两项功能有助于找到内存泄漏的操作行为。

Eclipse Memory Analysis Tools (MAT) 是一个分析Java堆数据的专业工具,用它可以定位内存泄漏的原因。

工具地址:

1.1 观察Heap

·运行程序,然后进入DDMS管理界面,如下:

PS : 点击工具栏上的来更新统计信息

点击右侧的Cause GC 按钮或工具栏上的即可查看当前的堆情况,如下:

主要关注两项数据:

o Heap Size 堆的大小,当资源增加,当前堆的空余空间不够时,系统会增加堆的大小,若超过上限(例如64M,视平台和具体机型而定)则会被杀掉

o Allocated 堆中已分配的大小,这是应用程序实际占用的内存大小,资源回收后,此项数据会变小

·查看操作前后的堆数据,看是否有内存泄漏

对单一操作(比如添加页,删除页)进行反复操作,如果堆的大小一直增加,则有内存泄漏的隐患。

1.2 利用MAT分析内存堆

DDMS 可以将当前的内存Dump成一个hprof格式的文件,MAT 读取这个文件后会给出方便阅读的信息,配合它的查找,对比功能,就可以定位内存泄漏的原因。

·获取hprof文件

点击工具栏上的按钮,将内存信息保存成文件。如果是用MAT Eclipse 插件获取的Dump文件,则不需要经过转换,Adt会自动进行转换然后打开。

·转换hprof文件

DDMS Dump 出的文件要经过转换才能被MAT识别,Android SDK提供了这个工具hprof-conv (位于sdk/tools下)

./hprof-conv xxx-a.hprof xxx-b.hprof

·用MAT打开转换后的hprof文件

1.3 Histogram 查询

用的最多的功能是Histogram,点击Actions下的Histogram项将得

到Histogram结果:

它按类名将所有的实例对象列出来,可以点击表头进行排序,在表的第一行可以输入正则表达式来匹配结果: