Java内存溢出问题排查分析

article/2025/11/3 7:26:04

目录

前言

一、MAT(Memory Analyzer Tool)

二、软件初识

三、捕获dump文件

1、主动方式

2、被动方式

四、分析dump文件

总结


前言

项目运行过程中,我们可能会遇到Java内存溢出Out Of Memory。此时我们可以借助内存分析工具MAT(Memory Analyzer Tool),来定位是哪里出现了问题。


一、MAT(Memory Analyzer Tool

下载地址:Eclipse Memory Analyzer Open Source Project | The Eclipse Foundation

注意:JDK-8建议使用11版本,否则会提示版本不兼容

二、软件初识

解压后目录内有个MemoryAnalyzer.ini文件,该文件里面有个-Xmx参数。该参数表示最大内存占用量,默认为1024m。
建议修改为小于本机内存大小,大于要分析的dump文件大小
-startup
plugins/org.eclipse.equinox.launcher_1.5.0.v20180512-1130.jar
--launcher.library
plugins/org.eclipse.equinox.launcher.win32.win32.x86_64_1.1.700.v20180518-1200
-vmargs
### -Xmx1024my原本默认为1024m,此处我修改为4096m
-Xmx4096m

三、捕获dump文件

        首先在程序中模拟出一段内存溢出的逻辑:

    @RequestMapping("/testOutOfMemory")@ResponseBodypublic void testOutOfMemory() throws Exception {String name = "Aikes";for (int i = 0; i < 10000000; i++) {name += name;}System.out.println(name);}

        然后启动项目,开始准备捕获dump文件。这里的捕获方式分为两种,一种是主动捕获,一种是被动捕获:

1、主动方式

        顾名思义,当内存溢出发生后,通过指令的方式手机当前应用程序下的内存使用情况。

1、通过(Linux) ps -ef|grep find 或者 (Dos)netstat -ano|findstr 查找java程序运行的PID

2、使用指令收集dump:jmap -dump:format=b,file=路径/heapdump.hprof  查到的PID

注意:主动获取dump文件必须是一出现内存异常就获取dump文件,这样获取的文件信息才比较准确。如果无法及时获取,推荐通过第二种方式获取dump文件。

2、被动方式

        该方式是启动Java服务时,增加额外参数。当程序发生内存溢出时自动收集dump文件:

1、-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/opt/oom/heapdump.hprof

        配置好后,调用我们预先模拟的内存溢出接口

        稍等片刻控制台开始打印日志,提示出现内存溢出并且已经收集到dump文件到指定目录:

四、分析dump文件

        打开下载好的mat软件,通过file-open打开抓取到的dump文件(hprof文件)

        点击切换视图,可以看到内存占用百分之八十是因为这个线程,继续点开发现是一个超大的字符串"AikesAikesAikes...."

        此时我们已经发现了内存溢出的直接原因,接下来要寻找出现这个问题的代码在哪里。再返回到最初的大饼图,点击最下面的details。然后点击See stacktrace 堆叠追踪。

        这里可以看到完整的堆栈信息,里面可以发现我们增加模拟溢出代码的那个Java文件,并且爆发内存溢出的代码行也可以对上,至此溢出分析结束。


总结

        模拟的内存溢出针对性很强,并且我们抓取dump文件也很及时,所以在分析的时候很简单。实际使用过程中面对的陷阱很多,需要从诸多可能中排查幕后凶手。Mat工具功能还很多,目前只是粗略的使用,后续如果有新的发现会继续补充到博文中。


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

相关文章

ajax书写方式及内部主要参数

书写方式 <!DOCTYPE html> <html> <head> <meta charset"utf-8"> <title>菜鸟教程(runoob.com)</title> <script src"https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js"> </script> <script&…

掌握ajax3:Ajax 中的高级请求和响应

对于很多 Web 开发人员来说&#xff0c;只需要生成简单的请求并接收简单的响应即可&#xff1b;但是对于希望掌握 Ajax 的开发人员来说&#xff0c;必须要全面理解 HTTP 状态代码、就绪状态和 XMLHttpRequest 对象。在本文中&#xff0c;Brett McLaughlin 将向您介绍各种状态代…

Ajax技术简介(http://www.51cto.com)

Ajax技术开发指南Ajax&#xff08;Asynchronous JavaScript and XML&#xff09;是结合了Java技术、XML以及JavaScript等编程技术&#xff0c;可以让开发人员构建基于Java技术的Web应用&#xff0c;并打破了使用页面重载的惯例。Ajax是使用客户端脚本与Web服务器交换数据的Web应…

AJAX初级

AJAX介绍 AJAX Asynchronous JavaScript and XML(异步的JavaScript和XML). 同步与异步的区别 同步的理解; 同步就是指一个进程在执行某个请求的时候&#xff0c;若该请求需要一段时间才能返回信息&#xff0c;那么这个进程将会一直等待下去&#xff0c;直到收到返回信息才继…

Ajax学习笔记-get请求参数-3

传统的表单内容会变成请求参数&#xff0c;自动拼接到对应的位置。get会放在请求地址的后面&#xff0c;post会放在请求体当中。 但是在Ajax中&#xff0c; 我们需要自己拼接请求参数&#xff0c;然后根据请求参数的不同&#xff0c;将请求参数放置在不同的位置。 路由&#xf…

【AJAX学习笔记三】ajax的post请求及其请求主体请求头的设置

AJAX的post请求及其请求行请求头的设置 一、POST请求 参照上一节的笔记&#xff0c;我们实现了get请求的方法&#xff0c;而POST方法的简单实现和GET方法类似&#xff0c;只需要在前端中将get请求修改为post。 xhr.open(POST, http://127.0.0.1:8000/server);在后端中将其接受…

Ajax参数对照及Success内容

本文是好久之前参考网上大佬教程&#xff0c;边学习边参考边做笔记&#xff0c;整理的内容&#xff0c;分享下大家学习~ 如果这位大佬看见&#xff0c;请评论留下您的名字和博客地址&#xff0c;我这里修改为【转载】 Ajax参数 jQuery 拥有完整的 Ajax 兼容套件。其中的函数和…

学习AJAX必知必会(2)~Ajax基本使用,设置请求行、请求体、请求头,服务端响应JSON数据

一、Ajax的基本使用 1、核心对象 XMLHttpRequest&#xff0c;AJAX 的所有操作都是通过该对象进行的。 2、发送ajax请求&#xff08;4个步骤&#xff09;&#xff1a; 创建xhr对象&#xff0c;然后open方法初始化&#xff0c;设置请求方式和请求路径&#xff0c;接着send方法…

尚硅谷AJAX教程

优点&#xff1a;无需刷新页面获取数据&#xff0c;允许你根据用户事件来更新部分页面内容 缺点&#xff1a;没有浏览历史&#xff0c;不能回退&#xff0c;存在跨域&#xff0c;SEO不友好 原生XHR请求 get请求 <body><button>获取数据</button><scri…

AJAX (2) — AJAX请求的基本操作、设置请求参数、发送POST请求,POST设置请求体、AJAX设置请求头信息

目录 一、AJAX请求的基本操作 1.server.js文件 2.GET.html文件 二、AJAX设置请求参数 三、AJAX发送POST请求 1.POST.html文件 2.server.js文件 四、POST设置请求体 五、AJAX设置请求头信息 1.预定义头信息 2.自定义头信息 一、AJAX请求的基本操作 先设计出一个需求&…

css ::after和::before详解

伪元素:before和:after添加的内容默认是inline元素 <style>p:before{content: "hello "}p:after{content: "you are handsome!"}</style><p>xx!</p>等价于下面的html结构:<p><span>hello </span>xxx!<span&g…

深入了解::before 和 ::after 伪元素

点击上方 前端瓶子君&#xff0c;关注公众号 回复算法&#xff0c;加入前端编程面试算法每日一题群 本文从最简单的开始&#xff0c;解释如何理解和使用::before和::after。然后再在实际使用场景中去应用它。 ::before和::after是什么? ::before和::after可以添加到选择器以创…

:after和:before的作用及使用方法

1. :before 和 :after 的主要作用是在元素内容前后加上指定内容&#xff0c;示例&#xff1a; HTML代码&#xff1a; <p>你好</p> CSS代码&#xff1a; p:before{content: Hello;color: red; } p:after{content: Tom;color: red; } 效果如图&#xff1a; 以上代码…

::before和::after伪元素的用法案例

CSS3中伪类采用单冒号写法&#xff0c;伪元素采用双冒号写法。 伪类举例——:hover,:link,:active,:target。 伪元素举例——::before,::after,::first-letter,::first-line,::selection。 一、介绍 今天写网页时遇到一个问题&#xff0c;视口的背景中插入一个小图标的话&a…

beforeSend 出现跨域问题,header里直接设置token就没问题----Day1

一开始前端调用后端接口出现跨域问题&#xff0c;右键查看元素&#xff0c;会有跨域错误提示&#xff0c;类似下图&#xff0c;后来找后端设置了一下&#xff0c;问题解决。可以登录获取token等参数了。 但是 请求设备列表时&#xff0c;beforeSend 中设置token却失败了&#x…

after和before的作用及使用方法

:after和:before的作用及使用方法 1、 :before 和 :after 的主要作用是在元素内容前后加上指定内容&#xff0c;示例&#xff1a; HTML代码&#xff1a; <p>你好</p>CSS代码&#xff1a; p:before{content: Hello;color: red; } p:after{content: Tom;color: r…

@Before, @BeforeClass, @BeforeEach 和 @BeforeAll之间的不同

1. 不同注解的区别如下&#xff1a; 特性 Junit 4Junit 5 在当前类的所有测试方法之前执行。注解在静态方法上。此方法可以包含一些初始化代码。BeforeClassBeforeAll 在当前类中的所有测试方法之后执行。注解在静态方法上。此方法可以包含一些清理代码。AfterClassAfterAll 在…

HTML中 :before 和 :after 的用法

1. :before 和 :after 的主要作用是在元素内容前后加上指定内容&#xff0c;示例&#xff1a; <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEed…

:before和:after的使用方法

伪元素可以让我们很方便的加入一个样式&#xff0c;比如在字体前加一个icon&#xff0c;或者加一个下换线&#xff0c;可以不占一个元素的位置&#xff0c;使用起来也很方便&#xff0c;现在介绍一下使用的方法。 注意&#xff1a;:before和:after中的content是必加项 <!DO…

@Before和@After的区别

通常我们使用JUnit的时候&#xff0c;会有一些方法需要提前或最后执行&#xff0c;则需要如下几种方式进行注解