使用MAT工具分析OOM问题

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<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造成线上故障

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用jmap工具可以对Java应用程序进行内存分析,帮助排查OOM问题。以下是使用jmap工具进行OOM排查的步骤: 1. 确认OOM错误:通过查看应用程序的日志或系统日志,确认是否发生了OOM错误。 2. 获取Java进程ID:使用`jps`命令获取Java进程的ID,例如:`jps -l`。 3. 使用jmap生成堆转储文件:运行以下命令生成堆转储文件(heap dump file): ``` jmap -dump:format=b,file=heapdump.bin <pid> ``` 其中,`<pid>`是Java进程的ID。 4. 分析堆转储文件:使用MAT(Memory Analyzer Tool)等内存分析工具来打开生成的堆转储文件。MAT是一款常用的Java堆内存分析工具,可以下载安装并打开生成的堆转储文件。 5. 查找内存泄漏:在MAT中,可以通过执行一系列分析操作来查找可能的内存泄漏。其中一种常用的分析是通过查看堆转储文件中的对象引用关系来定位可能导致内存泄漏的对象。 6. 分析对象占用内存情况:在MAT中,可以查看对象占用内存的情况,包括对象数量、大小和引用关系等信息。这有助于确定哪些对象占用了大量内存,可能导致OOM。 7. 优化代码和资源释放:根据分析结果,优化代码以避免内存泄漏或者减少内存占用。确保及时释放不再需要的对象和资源,使用合适的数据结构等。 请注意,使用jmap生成堆转储文件会在运行期间暂停Java进程一段时间,请在生产环境中谨慎使用。此外,内存分析工具使用需要一定的经验和技巧,对于复杂的问题,建议咨询专业的开发人员来进行排查和解决。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值