java内存溢出-Memory Analyzer(MAT)排查工具的简单使用

本文介绍了如何通过配置Tomcat服务获取.hprof内存快照文件,并利用MemoryAnalyzer(MAT)工具进行内存泄漏分析。文中详细阐述了MAT工具的主要功能,如Histogram、DominatorTree及RetainedHeap等特性,帮助开发者定位内存泄漏问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

工具的下载地址:http://www.eclipse.org/mat/downloads.php
Memory Analyzer(MAT)是一款内存分析工具,可以通过该工具打开.hprof文件进行分析内存溢出的原因。

在开始介绍这款工具使用前,先了解一下如何获取.hprof文件,首先我们需要在tomcat.service文件中加入内存溢出的相关参数:如下

CATALINA_OPTS=-Xms1024M -Xmx1024M -server -XX:+UseParallelGC -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/data/logsrvice

编辑文件,加入相关参数 vim /usr/lib/systemd/system/tomcat.service
在这里插入图片描述
在监控到内存溢出后,之前配置的内存溢出的路径/data/logsrvice
中会有内存溢出的相关文件,打开.hprof文件文件后,可以看到如下界面:
在这里插入图片描述
上图中的饼图展示了最大的几个对象所占内存的比例,点击饼图,可以看到左边会出现占比对应的对象信息:在这里插入图片描述
主要学习几个关键的工具:
Histogram可以列出内存中每个对象的名字、数量以及大小,如下图所示:在这里插入图片描述

Dominator Tree会将所有内存中的对象按大小进行排序,并且我们可以分析对象之间的引用结构,如下图所示:在这里插入图片描述

Retained Heap表示这个对象以及它所持有的其它引用(包括直接和间接)所占的总内存,因此从上图中看,前两行的Retained
Heap是最大的,我们分析内存泄漏时,内存最大的对象也是最应该去怀疑的。

另外我们可以看到,在每一行的最左边都有一个文件型的图标,这些图标有的左下角带有一个红色的点,有的则没有。带有红点的对象就表示是可以被GC
Roots访问到的,可以被GC
Root访问到的对象都是无法被回收的。那么这就说明所有带红色的对象都是泄漏的对象吗?当然不是,因为有些对象系统需要一直使用,本来就不应该被回收。
我们可以注意到,上图当中所有带红点的对象最右边都有写一个System
Class,说明这是一个由系统管理的对象,并不是由我们自己创建并导致内存泄漏的对象。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值