0

0

怎么在Java中分析OutOfMemoryError的Dump文件_MAT工具入门

P粉602998670

P粉602998670

发布时间:2026-03-19 11:44:01

|

113人浏览过

|

来源于php中文网

原创

MAT中“Dominator Tree”默认按不可回收内存排序,需重点关注char[]、byte[]、HashMap$Node、String等基础容器的异常实例数或大小,其背后常被静态ConcurrentHashMap或未清理ThreadLocal长期持有;勾选“Exclude weak/soft/phantom references”,用“Merge Shortest Paths to GC Roots”定位强引用链;大量IOUtils或TextNode提示JSON响应未释放;Histogram查java.lang.Class泄漏更有效,尤其Spring热部署场景;Leak Suspects报告仅作参考,需结合缓存配置与日志MDC检查;务必确认dump为OOM瞬间生成且文件完整,MAT内存不足时需调大-Xmx。

怎么在java中分析outofmemoryerror的dump文件_mat工具入门

怎么看MAT里“Dominator Tree”里的可疑对象

OOM后生成的堆转储(heap dump)文件,用MAT打开默认显示视图,它按“谁占着最多不可回收内存”排序。真正要盯的是排在前面、实例数异常多或单个对象特别大的char[]byte[]HashMap$NodeString这类基础容器——不是因为你写了多少new String(),而是它们背后被谁长期持有。

常见错误现象:java.lang.OutOfMemoryError: Java heap space发生后,MAT里看到几百MB的char[],但找不到业务类直接引用它;点开“Path to GC Roots”发现最终停在某个静态ConcurrentHashMap或未关闭的ThreadLocal变量上。

  • 务必勾选“Exclude weak/soft/phantom references”,否则大量缓存类(如SoftReference包装的图片)会干扰判断
  • 右键某个可疑对象 → “Merge Shortest Paths to GC Roots”比默认的“with all references”更干净,能快速定位强引用链
  • 如果看到大量重复的org.apache.commons.io.IOUtilscom.fasterxml.jackson.databind.node.TextNode,大概率是JSON解析后没释放流或缓存了完整响应体

为什么用“Histogram”查java.lang.Class泄漏比查对象更有效

很多OOM其实不是堆里塞满了业务对象,而是类加载器泄漏(ClassLoader leak),导致老年代堆满却GC不掉——这时候java.lang.Class实例数会持续上涨,每个只占几KB,但加起来压垮元空间或触发Full GC失败。

使用场景:Spring Boot热部署、OSGi插件、自定义URLClassLoader反复加载jar时最典型;MAT里Histogram视图按类名统计实例数,比肉眼扫快得多。

立即学习Java免费学习笔记(深入)”;

  • Histogram中输入java.lang.Class回车,看“Retained Heap”列是否随重启次数线性增长
  • 右键某行 → “List objects” → “with incoming references”,再点一个Class实例 → “Path to GC Roots”,重点看是不是被某个静态Map<String, Class>或线程上下文类加载器(Thread.currentThread().getContextClassLoader())持有着
  • 注意区分JDK自带类(如java.util.ArrayList)和你自己的com.xxx.service.UserServiceImpl$$EnhancerBySpringCGLIB$$——后者才是泄漏源

Leak Suspects报告不准?别全信,但要看它标红的引用链

MAT自动运行的Leak Suspects报告只是启发式扫描,它把“持有大量对象且本身不被GC Roots直接引用”的集合类(如ArrayListLinkedHashMap)标为嫌疑,但90%的情况是你的缓存逻辑写得太糙,不是真正的泄漏。

WisPaper
WisPaper

复旦大学研发的AI学术搜索工具,5分钟内筛选1000篇论文

下载

性能影响:这个报告本身不耗时,但如果你在1GB以上的dump上反复点“Run Report”,MAT会重新计算支配树,卡住几分钟。

  • 先看报告顶部的“Details”里写的“Problem Suspect 1”,它给出的“Accumulated Objects”数量是否合理(比如一个订单系统缓存了50万Order对象,但实际日活才2千,就明显不对)
  • 点开“See stacktrace”——如果调用栈里全是org.springframework.cache.interceptor.CacheInterceptorcom.google.common.cache.LocalCache,优先检查缓存配置的maximumSizeexpireAfterWrite
  • 如果报告里提到java.util.logging.Loggerorg.slf4j.impl.Log4jLoggerAdapter,往往是日志框架绑定的MDC没清理,或者Logger被静态Map强引用

分析前必须确认dump文件是哪个阶段的

同一个OOM可能对应多个dump:JVM参数-XX:+HeapDumpOnOutOfMemoryError生成的是抛出OutOfMemoryError瞬间的堆快照,而用jmap -dump:format=b,file=heap.hprof <pid>手动抓的可能是GC刚结束、对象已部分回收的状态——两者看到的主导对象可能完全不同。

容易踩的坑:用线上机器jmap抓dump时没加-F强制参数,结果返回“Unable to open socket file”,或者抓到一半JVM挂了;又或者开发机用VisualVM连远程服务,网络抖动导致dump文件损坏,MAT打开报错Invalid header: expected 0x4846524F46464245

  • 检查dump文件大小是否合理:Java 8下,一个正常运行的2G堆,OOM dump通常在1.2–1.8G之间;如果只有200MB,大概率是CMS GC失败后只dump了年轻代
  • file heap.hprof命令看文件头,确认是“Java Heap Dump Binary File”而非“data”或“empty”
  • 如果MAT提示“Parsing heap dump failed with java.lang.OutOfMemoryError: Java heap space”,不是dump坏了,是你给MAT分配的内存不够,在MemoryAnalyzer.ini里改-Xmx4g再试

真正难的不是找到那个大数组,而是判断它该不该存在、谁该负责清理、清理时机是否被其他同步逻辑阻塞——这些没法靠工具标红,得翻代码里那几行cache.put(key, value)cache.remove(key)中间夹着什么。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

887

2023.06.15

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

767

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

756

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

401

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

462

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

453

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

433

2023.08.02

java在线网站
java在线网站

Java在线网站是指提供Java编程学习、实践和交流平台的网络服务。近年来,随着Java语言在软件开发领域的广泛应用,越来越多的人对Java编程感兴趣,并希望能够通过在线网站来学习和提高自己的Java编程技能。php中文网给大家带来了相关的视频、教程以及文章,欢迎大家前来学习阅读和下载。

17171

2023.08.03

Go Web框架Gin接口开发与中间件设计实践
Go Web框架Gin接口开发与中间件设计实践

本专题围绕 Go 在 Web 后端开发中的主流框架 Gin 展开,系统讲解高性能接口开发与中间件机制设计。内容涵盖路由分组、请求绑定、参数校验、统一响应封装、日志与鉴权中间件实现,以及接口限流与异常处理策略。通过实战项目案例,帮助开发者构建结构清晰、性能优良的 Go Web 服务体系,提升接口开发效率与系统可维护性。

7

2026.03.19

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.6万人学习

C# 教程
C# 教程

共94课时 | 11.7万人学习

Java 教程
Java 教程

共578课时 | 84.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号