内存分析工具MAT的使用
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 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,file=heap.bin
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堆数据的专业工具,用它可以定位内存泄漏的原因。
工具地址: https:///mat/
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结果:
它按类名将所有的实例对象列出来,可以点击表头进行排序,在表的第一行可以输入正则表达式来匹配结果: