【Java】使用Memory Analyzer分析OOM进程堆dump文件

        Memory Analyzer是一款非常好用的、开源的JVM内存Dump分析工具,可以用于分析导致JVM老年代或者堆OutOfMemory的对象。

        最新版下载地址:

        https://www.eclipse.org/mat/downloads.php

        下载完成后,建议修改软件默认的JVM堆内存的配置(初始化堆内存、最大堆内存),文件路径如下:

        C:\Program Files\mat\MemoryAnalyzer.ini

修改前:

-startup
plugins/org.eclipse.equinox.launcher_1.6.200.v20210416-2027.jar
--launcher.library
plugins/org.eclipse.equinox.launcher.win32.win32.x86_64_1.2.200.v20210429-1609
-vmargs
-Xmx1024m

修改后:

-startup
plugins/org.eclipse.equinox.launcher_1.6.200.v20210416-2027.jar
--launcher.library
plugins/org.eclipse.equinox.launcher.win32.win32.x86_64_1.2.200.v20210429-1609
-vmargs
-Xms10240m
-Xmx10240m

        这个内存设置建议比本机PC的最大内存要小,并预留系统运行所需的最小内存。

        除了上面的JVM运行内存设置之外,1.12.0版本需要JDK11.0以及以上的版本,如果使用JDK1.8,则需要下载老一点的版本来支持Mat的运行。

C:\Users\Administrator>java -version
java version "11.0.13.0.2" 2021-10-26 LTS
Java(TM) SE Runtime Environment 18.9 (build 11.0.13.0.2+1-LTS-1)
Java HotSpot(TM) 64-Bit Server VM 18.9 (build 11.0.13.0.2+1-LTS-1, mixed mode)

        JDK安装、环境变量配置正确的话,下面就可以正常打开和运行Eclipse Memory Analyzer了,也就是我们说的Mat。通过菜单 [file] - [Open File...] 打开导出来的堆Dump文件,工具就会自动分析堆Dump中可能导致内存泄漏的代码块了。

         从下面的自动分析结果来看,可以看出ehcache(Ehcache)这个缓存工具占用了JVM内存中的918.4MB,导致了内存的泄漏。这种问题一般都是开发往缓存写了很多数据,但是没有及时清理导致的。那为什么一个缓存软件会占用JVM堆内存呢?从网上搜索关于ehcache缓存数据的途径来看,在Ehcache中对于缓存的存储主要有三种方式:分别是堆内存、非堆内存和磁盘。其中非堆内存是针对于企业版Ehcache才有的功能,它可以不受Java GC的影响,能够创建很大的缓存。至此,可以确定开发人员使用了开源ehcache,并且将大量的数据缓存到了堆内存中,且数据无法清理(对象仍然存活),导致了JVM内存的泄漏。ehcache的具体我没有研究过,但是从上面的介绍来看,解决问题的方式,一个是让开发限制EHCACHE使用JVM堆内存的大小,同时提升JVM内存的大小。另外一种方式,就是使用磁盘取代JVM堆内存来存储缓存的数据(这种方式可能会导致IO效率降低)。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

cnskylee

技术分享我是认真的,期待您打赏

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值