Java 内存溢出(二)使用 MAT 分析 .hprof 内存映像文件

article/2025/10/13 22:04:51

目录

    • 一、内存溢出时自动导出 .hprof 文件
    • 二、下载安装 MAT
    • 三、启动 MAT
    • 四、MAT 分析 hprof 文件
      • 1.Overview 概览
      • 2.Leak Suspects 溢出原因猜测
      • 3.Histogram 对象实例数量排序
      • 4.Dominator Tree 支配树

.hprof 文件: 是 java 项目的 Heap Dump 文件,也叫内存映像文件、内存快照文件,可以存放一个 java 进程在某个时间点的内存快照。生成 Heap Dump 文件的方式有两种:一是使用 jmap 命令手动导出,二是启动脚本中添加 -XX:+HeapDumpOnOutOfMemoryError 参数自动导出。本文中只涉及第二种。

一、内存溢出时自动导出 .hprof 文件

1.新建一个文本文件,命名为 HeapOOM.java,内容如下:

import java.util.ArrayList;
import java.util.List;public class HeapOOM {static class User {}public static void main(String[] args) {List<User> list = new ArrayList<>();while (true) {list.add(new User());}}
} 

2.打开控制台,执行如下命令编译 java 文件:

javac HeapOOM.java

3.使用如下命令运行 java 文件:

java -Xms10M -Xmx10M -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=./ HeapOOM
  • -Xms10M 堆内存最小10M;
  • -Xmx10M 堆内存最大10M;
  • -XX:+HeapDumpOnOutOfMemoryError 内存溢出时自动导出堆内存快照;
  • -XX:HeapDumpPath=./ 内存快照保存位置,不指定默认当前路径

请添加图片描述

二、下载安装 MAT

下载地址: https://www.eclipse.org/mat/downloads.php

在这里插入图片描述

点击 Download。

在这里插入图片描述

注意:目前最新的版本 Memory Analyzer 1.13.0 Release,是只支持在 JDK 11 下运行的

如果想下载 JDK8 下运行的版本,可以点击 Other Releases > Previous Releases。

请添加图片描述

选择版本:Memory Analyzer 1.9.2 Release

请添加图片描述

三、启动 MAT

双击 exe 文件启动:

请添加图片描述

请添加图片描述

注意: 如果 hprof 文件太大,需要调整它的内存才可以完成大 dump 文件的加载,这个配置文件需要 exe 启动后会自动生成:

请添加图片描述

请添加图片描述

四、MAT 分析 hprof 文件

点击 Open a Heap Dump,选择一个 hprof 文件打开:

请添加图片描述

1.Overview 概览

概览中,我们可以看到对象所占的比例及排序。显然有个对象不正常,一共上限 10M 的内存占用了 6.9 M。

请添加图片描述

2.Leak Suspects 溢出原因猜测

点击下方的 Leak Suspects,可以查看 MAT 的详细分析结果,猜测导致堆栈溢出的原因:

请添加图片描述

请添加图片描述

根据上图可以看到有一个猜测的原因:

  • 主程序占用了 92.88% 的内存,其中 Object 对象过多。

毫无疑问是对象实例过多导致的内存溢出,具体是哪个对象呢,下一步怎么分析呢?

3.Histogram 对象实例数量排序

点击下图所示柱状图(Histogram)查看对象实例数量排序,在 Regex 中可以用输入正则表达式把自己的包名,输入后回车过滤:

请添加图片描述

请添加图片描述

这里的 User 实例有 36w 个,显然不正常,我们可以查下是谁引用的:

请添加图片描述

我们可以看到是 main 线程中引用了这些对象。(当前示例较为简单,如果是项目中可以明确看到是哪个类中的引用导致的)

请添加图片描述

4.Dominator Tree 支配树

支配树: MAT 提供了一个成为支配树(Demonitor Tree)的对象图。支配树体现了对象实例间的支配关系。在对象引用图中,所有指向对象 B 的路径都经过对象 A,则认为对象 A 支配对象 B。如果对象 A 是离对象 B 最近的一个支配对象,则认为对象 A 为对象 B 的直接支配者。

支配树是基于对象间的引用图所建立的,它有以下基本性质:

  • 对象 A 的子树(所有被对象 A 支配的对象集合)标识对象 A 的保留集(Retained Set),即深堆;
  • 如果对象 A 支配对象 B,那么对象 A 的直接支配者也支配对象 B;
  • 支配树的边与对象引用图的边不直接对应。

我们可以理解为支配图就是用来查看类使用内存比例的,图中使用最多的类对应溢出原因猜测中的内存使用率 92.88%。

请添加图片描述

以上就是 MAT 分析 .hprof 文件的常用功能。

整理完毕,完结撒花~





参考地址:

1.导出dump文件及MAT安装分析,https://blog.csdn.net/lixiangchibang/article/details/124721472

2.【JVM笔记】支配树(Dominator Tree),https://blog.csdn.net/lijibai_/article/details/126526375


http://chatgpt.dhexx.cn/article/rONxCii4.shtml

相关文章

Solr文档学习--Solrj的使用

首先启动solr solr.cmd startSolrClient 主要通过SolrClient来连接到Solr服务器 SolrClient有4个实现类 CloudSolrClient SolrJ client class to communicate with SolrCloud. Instances of this class communicate with Zookeeper to discover Solr endpoints for SolrClou…

solrj 对solr 的操作

使用SolrJ操作Solr会比利用httpClient来操作Solr要简单。SolrJ是封装了httpClient方法&#xff0c;来操作solr的API的。SolrJ底层还是通过使用httpClient中的方法来完成Solr的操作。 1、 首先&#xff0c;你需要添加如下jar包 其中apache-solr-solrj-3.4.0.jar、slf4j-api-1.6…

SolrJ的使用

CommonsHttpSolrServer CommonsHttpSolrServer 使用HTTPClient 和solr服务器进行通信。 Java代码 String url "http://localhost:8983/solr"; SolrServer server new CommonsHttpSolrServer( url ); String url "http://localhost:8983/solr";Sol…

sorl

solr&#xff1a; 层面搜索、命中醒目显示并且支持多种输出格式&#xff08;包括 XML/XSLT 和 JSON 格式&#xff09;&#xff0c;Solr 可以阅读和使用构建到其他 Lucene 应用程序中的索引。 安装&#xff1a;http://blog.csdn.net/millery22/article/details/51446014 对外提…

Solr和Solrj的使用

Solr(4.10.3)&Solrj 部署环境 1.拷贝solr solr-4.10.3\example\solr 目录到【如E:/solr/】,重命名solr为solrhome 【E:/solr/solrhome】 solrhome:solr里面有几个文件 collection1:有一个默认名称为collection1的SolrCore索引库 conf&#xff1a;SolrCore运行配置信息 co…

SolrJ的查询

1.solr是一个全文检索引擎系统,通过部署到tomcat下就可以独立运行,通过http协议对外提供全文检索服务, 就是索引和文档的正删改查服务 2. solr直接操作索引库和文档库, 我们的业务系统中可以使用solrJ(solr的客户端,就是一堆jar包)来调用solr服务端, 让solr服务端操作文档库和…

使用solrJ操作solr常用方法

既然学的是java那么肯定需要用java代码来进行对solr的操作&#xff0c;如果知道在solr后台管理界面进行增删改查等操作&#xff0c;那么用solrJ操作solr会更好理解。 solrJ介绍 solrJ是一个用来访问solr的java客户端&#xff0c;提供了索引和搜索的方法&#xff08;将一些常用…

solr快速上手:整合SolrJ实现客户端操作(九)

0. 引言 我们前面学习了solr的服务端基础操作&#xff0c;实际项目中我们还需要在客户端调用solr&#xff0c;就像调用数据库一样&#xff0c;我们可以基于solrJ来实现对solr的客户端操作 1. SolrJ简介 SolrJ 是 Solr官方提供的 Java 客户端库&#xff0c;主要用于与 Solr 服…

全文检索solr(五)Solrj的使用

什么是solrj solrj是访问Solr服务的java客户端&#xff0c;提供索引和搜索的请求方法&#xff0c;如下图&#xff1a; Solrj和图形界面操作的区别就类似于数据库中使用jdbc和mysql客户端的区别一样。 需求 使用solrj调用solr服务实现对索引库的增删改查操作。 环境准备 So…

Solr-Solrj简单使用

一、SolrJ简介 SolrJ是操作Solr的Java客户端&#xff0c;它提供了增加、修改、删除、查询Solr索引的Java接口。通过solrJ提供的API接口来操作solr服务&#xff0c;SolrJ底层是通过使用httpClient中的方法来完成Solr的操作。 二、依赖配置 <dependency><groupId>…

solrj

文章目录 1.什么是solrj?2.搭建工程2.1.导入相关jar包 3.对索引库做增删改查3.1.添加&#xff08;以实体类的方式&#xff09;添加方法 3.3.修改&#xff08;update&#xff09;3.4.删除以ID删除批量删除&#xff08;以ID&#xff09;以条件删除&#xff08;query&#xff09;…

Solr系列四:Solr(solrj 、索引API 、 结构化数据导入)

一、SolrJ介绍 1. SolrJ是什么&#xff1f; Solr提供的用于JAVA应用中访问solr服务API的客户端jar。在我们的应用中引入solrj&#xff1a; <dependency><groupId>org.apache.solr</groupId><artifactId>solr-solrj</artifactId><version>7…

solr学习之solrj

solrJ是访问Solr服务的JAVA客户端&#xff0c;提供索引和搜索的请求方法&#xff0c;SolrJ通常嵌入在业务系统中&#xff0c;通过solrJ的API接口操作Solr服务。 一 .maven的环境jar包配置 <!-- https://mvnrepository.com/artifact/org.apache.solr/solr-solrj --><d…

Pytorch实现逻辑斯蒂回归模型 代码实操

初学者学习Pytorch系列 第一篇 Pytorch初学简单的线性模型代码实操 第二篇 Pytorch实现逻辑斯蒂回归模型 代码实操 文章目录 初学者学习Pytorch系列前言一、先上代码二、测试结果1. 数据结果2.画图结果 总结 前言 上一篇的数据中&#xff0c;是这样子的例子 x_data代表的学习的…

回归分析(三)二项逻辑斯蒂回归模型

回归分析&#xff08;三&#xff09;二项逻辑斯蒂回归 学了一段时间突然又遇到逻辑斯蒂回归&#xff0c;结果发现已经忘完了&#xff0c;所以今天重新梳理一下。 &#xff08;1&#xff09;逻辑斯蒂分布 先看一下逻辑斯蒂分布函数 F ( x ) F(x) F(x)&#xff0c;其概率密度函数…

回归分析:逻辑斯蒂回归模型,可视化分类决策边界

文章目录 逻辑斯蒂回归模型逻辑斯蒂回归模型python案例 逻辑斯蒂回归模型 前面的例子都是在用线性模型解决回归任务&#xff0c;那么线性模型能否完成分类任务呢&#xff1f;相较于回归任务&#xff0c;分类任务的预测值是离散的&#xff0c;比如二分类问题&#xff0c;可以用…

机器学习:逻辑斯蒂回归

目录 逻辑回归模型介绍逻辑斯蒂分布二项逻辑斯谛回归模型目标函数 逻辑回归模型介绍 原理&#xff1a; 逻辑斯谛回归&#xff08;logistic regression&#xff09;是经典的分类方法&#xff0c;它属于对数线性模型&#xff0c;原理是根据现有的数据对分类边界线建立回归公式&a…

《PyTorch深度学习实践》06 逻辑斯蒂回归 代码

视频&#xff1a;06.逻辑斯蒂回归_哔哩哔哩_bilibili 参考文章&#xff1a;pytorch 深度学习实践 第6讲 逻辑斯蒂回归_会游泳的小雁的博客-CSDN博客 网络模型的基本框架 1步骤&#xff1a; 1.Prepare dataset 2.Design model using Class &#xff08;inherit from nn.Modul…

逻辑斯蒂回归 matlab实现

说明 我将试图从感知机的基础上说明逻辑回归的一般性原理和学习及预测方法&#xff0c;其中缺少一些必要的证明&#xff0c;包括了一个二分类问题的实例。其中关于感知机的实验在 机器学习 专栏中有介绍。 从感知机到逻辑斯蒂回归 感知机模型&#xff1a; 应用范围&#xf…

Lecture6 逻辑斯蒂回归(Logistic Regression)

目录 1 常用数据集 1.1 MNIST数据集 1.2 CIFAR-10数据集 2 课堂内容 2.1 回归任务和分类任务的区别 2.2 为什么使用逻辑斯蒂回归 2.3 什么是逻辑斯蒂回归 2.4 Sigmoid函数和饱和函数的概念 2.5 逻辑斯蒂回归模型 2.6 逻辑斯蒂回归损失函数 2.6.1 二分类损失函数 2.…