使用MAT工具分析OOM问题
创始人
2024-05-25 23:30:39
0

1、添加jvm参数 保存堆内存快照
-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=存放路径

2、下载MAT工具
下载地址:
https://www.eclipse.org/mat/downloads.php
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
3、启动如果遇到 Version 1.8.0 102 of the JVM is not suitable for this product, Version: 11or greater is required.错误需要指向jdk ,找到MemoryAnalyzer.ini 配置文件
添加
-vm
C:\Program Files\Java\jdk-11\bin\javaw.exe 即可
在这里插入图片描述
jdk11下载地址
链接: https://pan.baidu.com/s/1pCQIKILiQlGVbYGxKaWcQw?pwd=85sg
提取码: 85sg

4、启动MAT工具 导入dump文件

在这里插入图片描述
可以看到有代码占用了大量内存没有释放导致了OOM问题

再次分析点击
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

可以看到这个对象占用了大量堆内存没有释放因此定位原因
更多工具使用方法这里不再一一介绍请自行查找

5、本地测试修VM参数保存dump文件
-Xmx1024m -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=D:\dump
在这里插入图片描述

写一段代码测试

import lombok.Data;@Data
public class Tom {private String name;private Integer age;private String [] friends;
}
public static void main(String[] args) throws InterruptedException {Map map = new HashMap();int counter = 1;while(true) {Thread.sleep(10);Tom tom = new Tom();String [] friends = new String[counter];for (int i = 0; i < friends.length; i++) {friends[i] = "friends"+i;}tom.setAge(counter);tom.setName("tom"+counter);tom.setFriends(friends);map.put(tom.getName(),tom);if(counter%100==0)System.out.println("put"+counter);counter++;}
}

由于是死循环一直创建Tom对象 所有知道内存使用完毕抛出异常OOM生成dump文件
在这里插入图片描述

总结:
使用MAT工具可以辅助我们定位问题,但在实际编码中要注意堆内存对象创建释放问题,防止发生OOM造成线上故障

相关内容

热门资讯

监控摄像头接入GB28181平... 流程简介将监控摄像头的视频在网站和APP中直播,要解决的几个问题是:1&...
Windows10添加群晖磁盘... 在使用群晖NAS时,我们需要通过本地映射的方式把NAS映射成本地的一块磁盘使用。 通过...
protocol buffer... 目录 目录 什么是protocol buffer 1.protobuf 1.1安装  1.2使用...
在Word、WPS中插入AxM... 引言 我最近需要写一些文章,在排版时发现AxMath插入的公式竟然会导致行间距异常&#...
修复 爱普生 EPSON L4... L4151 L4153 L4156 L4158 L4163 L4165 L4166 L4168 L4...
【PdgCntEditor】解... 一、问题背景 大部分的图书对应的PDF,目录中的页码并非PDF中直接索引的页码...
Fluent中创建监测点 1 概述某些仿真问题,需要创建监测点,用于获取空间定点的数据࿰...
educoder数据结构与算法...                                                   ...
MySQL下载和安装(Wind... 前言:刚换了一台电脑,里面所有东西都需要重新配置,习惯了所...
MFC文件操作  MFC提供了一个文件操作的基类CFile,这个类提供了一个没有缓存的二进制格式的磁盘...