使用MAT工具分析OOM问题

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

2、下载MAT工具
下载地址:
https://www.eclipse.org/mat/downloads.php
使用MAT工具分析OOM问题_第1张图片

使用MAT工具分析OOM问题_第2张图片
使用MAT工具分析OOM问题_第3张图片
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 即可
使用MAT工具分析OOM问题_第4张图片
jdk11下载地址
链接: https://pan.baidu.com/s/1pCQIKILiQlGVbYGxKaWcQw?pwd=85sg
提取码: 85sg

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

使用MAT工具分析OOM问题_第5张图片
可以看到有代码占用了大量内存没有释放导致了OOM问题

再次分析点击
使用MAT工具分析OOM问题_第6张图片
使用MAT工具分析OOM问题_第7张图片
使用MAT工具分析OOM问题_第8张图片

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

5、本地测试修VM参数保存dump文件
-Xmx1024m -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=D:\dump
使用MAT工具分析OOM问题_第9张图片

写一段代码测试

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<String,Tom> map = new HashMap<String,Tom>();
	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问题_第10张图片

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

你可能感兴趣的:(java,jvm,java,开发语言)