博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
内存分析工具MAT(Memory Analyzer Tool)的安装与使用
阅读量:4106 次
发布时间:2019-05-25

本文共 2821 字,大约阅读时间需要 9 分钟。

一、安装

1.1、在Eclipse上安装MAT插件,步骤如下:
点击Help,Install New Soft,就出现了以下Install界面:然后我们点击ADD,在弹出的框中填上Mat插件的地址:,确定后,
点击Select All,点击Next,之后就一直确定,就能安装了。安装之后需要重启Eclipse.

image.png

1.2、安装独立版本的MAT
把下载好的压缩包解压到本地任意一个文件夹里,和eclipse一样,解压完成就可以使用了。下图是我的解压路径。解压完成点击箭头指向的执行文件启动MAT程序。
下载地址:

image.png

 

二、使用

2.1、实例: 我启动一个web容器,在其中配置一个selvelt,selvelt启动时会执行一条问题程序,导致堆内存溢出,代码如下

 

public class myselvelt extends HttpServlet {    private String[] strings = new String[1000];    public void init(ServletConfig config) {        System.out.println("-----------------------------");        Timer timer = new Timer();        timer.schedule(new mytime(), 10000);            }        class mytime extends TimerTask{        @Override        public void run() {            System.out.println("-------------mytime----------------");            Map
m = new HashMap
(); int i = 0; do{ OutOfMemoryTest test = new OutOfMemoryTest(); m.put(String.valueOf(i), test); i++; }while(i<100000); } } protected void doGet(HttpServletRequest req,HttpServletResponse resp) throws ServletException,java.io.IOException { resp.getWriter().println("I am httpServlet doGet()"); } protected void doPost(HttpServletRequest req,HttpServletResponse resp) throws ServletException,java.io.IOException { resp.getWriter().println("I am httpServlet doPost()"); } public void destory(ServletConfig config){ }}

然后设置容器运行参数:-Xms128m -Xmx256m -XX:MaxPermSize=256m

启动程序,直到堆内存溢出

 

image.png

2.2、导入dump的文件

 

image.png

 

image.png

 

image.png

 

image.png

2.3、分析问题

首先由此饼状图就可以看出问题出现a、b上,再看两问题的简单描述,b是出现在org.apache.catalina.loader.WebappClassLoader 中的,此是容器涉及的区域,可以排除,再看a描述为一个Timer-5的线程占据的51%的堆空间,所以基本可以断定问题出现在a上(这里还有一个比较直观,但不高效的办法,就是重新设置一下运行容器的参数,运行直到出错,再导入dump的文件,就可以对比饼状图,百分百变化很明显的就是问题原因出现的位置)

 

image.png

 

image.png

 

再查看问题a的详情

先看到累积点的最短路径

 

image.png

可以看到线程:地址是0xf7efbc18 ,名称为Timer-5,其中累积的为一个[java.util.HashMap]
然后再看累积对象所在树的详情

image.png

可以看到积累了很多HashMap

然后切换一个视图查看

 

image.png

 

image.png

在第一行输入问题线程名(Timer-5)进行查询,进入找到累积点(堆占据最大)

image.png

 

image.png

可以看到累积了22364个hashMap<String,OutOfMemoryTest>对象,这就是问题的根源

然后再跟踪堆栈找到问题代码所在位置

 

image.png

 

此处比较简单,就是一个Timer-->myselvelt-->OutOfMemoryTest-->OutOfMemoryError

可以看到问题可能是myselvelt.java的34行,OutOfMemoryTest.java的7行
找到对应的代码区查找

 

image.png

 

image.png

这里基本就可以会转到文章开始了,也就是问题实例,是myselvelt中的问题所在点(myselvelt.java的34行)

三、获取内存dump文件

3.1、通过jdk自带的jmap命令获取 jmap -dump:format=b,file=D:\dump\dumpName.hprof [pid]

 

image.png

 

3.2、在jdk启动加参数中加: -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=D:\dump\ ,然后应用启动后出现内存异常则会自动导出dump文件,默认的文件名是:java_pid<进程号>.hprof。

注意:获取dump文件必须是一出现内存异常就获取dump文件,这样获取的文件信息才比较准确,如果过了一段时间在导出dump文件,就会因gc的缘故,导致信息不准确,所以推荐第二种方式获取dump文件。

作者:笑才
链接:https://www.jianshu.com/p/c6e2abb9f657
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

你可能感兴趣的文章
Qt5.01 + MinGW4.7 部署发布程序出现的问题
查看>>
为Qt程序配上漂亮的桌面图标
查看>>
使用QSplashScreen做QT程序欢迎画面
查看>>
Qt中如何检测程序是Debug版还是Release版
查看>>
QT中生成字符串md5的方法
查看>>
Fedora 16为Grub2添加修改背景图片和字体颜色
查看>>
用SecureCRT来上传和下载数据
查看>>
Qt 5简介
查看>>
配置/etc/sysconfig/network-scripts/ifcfg-ethx [ IPV4篇 ]
查看>>
systemctl命令用法
查看>>
开启Win8的无线路由器功能(Wifi共享)
查看>>
解读QML之一http://blog.csdn.net/chenlong12580/article/details/8596342
查看>>
解读QML之二
查看>>
解读QML之三
查看>>
解读QML之四
查看>>
macOS下MySQL 8.0 安装与配置教程
查看>>
master合并分支时提示“Already up-to-date”
查看>>
IOS 推送消息 php做推送服务端
查看>>
linux下跑CPU的命令 烤机
查看>>
如何使用PHP编写daemon process
查看>>