JVM-使用MAT(Memory Analyzer Tool)内存分析工具分析JVM老生代增长异常

本文主要是介绍JVM-使用MAT(Memory Analyzer Tool)内存分析工具分析JVM老生代增长异常,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

JVM-使用MAT(Memory Analyzer Tool)内存分析工具分析JVM老生代增长异常

最近通过监控发现java服务的堆内存每天都会上涨150MB左右,通过分析监控发现是堆内存中的PS Old Gen老生代)区域每天上涨导致堆内存上涨,而且也不会被回收; 本篇文章就带领大家通过MAT(Memory Analyzer Tool)内存分析工具一起找出老生代内存长涨的对象

目录

  • JVM-使用MAT(Memory Analyzer Tool)内存分析工具分析JVM老生代增长异常
  • 一、准备内容
  • 二、分析老生代内存区域中的对象
    • 2.1 获取java服务的PID
    • 2.2 Dump堆内存成.hprof文件
    • 2.3 获取老生代内存区域的内存地址范围
    • 2.4 使用MAT分析老生代内存中的对象

一、准备内容

  1. MAT(Memory Analyzer Tool)内存分析工具
    点击【官方下载】进行下载;
    在这里插入图片描述
    MAT依赖本地JAVA_HOME环境变量设置,如果本地JAVA_HOME是JDK8的话,直接将JDK11下载到MAT安装目录,并将JDK11的路径通过-vm参数添加到MemoryAnalyzer.ini配置文件中
    在这里插入图片描述

  2. JDK11 MAT依赖最低JDK11,请大家自行前往oracle官方网站下载;

  3. JVisualvm、Jmap或【阿里开源的java分析工具Arthas】;

  4. vjmap

一款开源的增强版jmap,用于输出老生代内存区的内存地址,【下载地址】
可以下载vjtools,通过maven编译vjmap,通过maven的install命令会在目标目录生成vjmap.zip,里面是完整的运行环境
在这里插入图片描述

二、分析老生代内存区域中的对象

2.1 获取java服务的PID

  1. 如果是Windows系统的话,可以通过系统的任务管理器中获取
    Windows获取java服务PID
  2. 如果是Linux系统,可以通过命令来进行查询PID
# ps -aef | grep java

如下图所示:
Linux查询java服务的PID
3. JVisualVM可以显示java服务的PID
在这里插入图片描述

备注: 以上3种方式选一种即可

2.2 Dump堆内存成.hprof文件

  1. 通过JVisualVM(Oracle JDK内置的监控工具)Dump出堆内存信息
    • 点击监控页签->[堆Dump]按钮在这里插入图片描述
    • 稍等一会就会生成hprof文件,在详情画面会显示导出路径,右击此路径可以复制在这里插入图片描述
  2. 通过Arthas工具中的heapdump命令导出堆内存中的信息
  • 启动arthas-boot.jar,输入PID对应的序号
java -jar arthas-boot.jar

如下图所示:
在这里插入图片描述

  • 执行导出堆内存
[arthas]$ heapdump

在这里插入图片描述

说明:上面是导出堆内存信息的两种方式,选一种即可,需复制下hprof文件的导出路径,MAT会用到。

2.3 获取老生代内存区域的内存地址范围

  1. 运行vjmap命令输出老生代的内存地址
vjmap.bat -address 15832 

在这里插入图片描述

Linux的运行vjmap.sh -address PID命令即可

输出信息:
PSYoungGen [
eden = [0x00000007d5560000,0x00000007db9e1478,0x00000007f3250000] ,
from = [0x00000007f3250000,0x00000007f3be8000,0x00000007f9920000] ,
to = [0x00000007f9a40000,0x00000007f9a40000,0x0000000800000000] ]
PSOldGen [ [0x0000000780000000,0x00000007846715f8,0x00000007d5560000] ]

由此可以得出老生代内存地址范围为PSOldGen [ [0x0000000780000000,0x00000007846715f8,0x00000007d5560000] ],其中
0x0000000780000000:PSOldGen的起始地址
0x00000007846715f8:表示PSOldGen已使用了的结束地址;
0x00000007d5560000:表示PSOldGen的结束地址;

2.4 使用MAT分析老生代内存中的对象

  1. 打开刚才导出的hprof文件
    在这里插入图片描述

  2. 进入OQL编辑画面,执行查询老生代内存区域中的对象
    在这里插入图片描述
    查询OQL语句如下:

SELECT * 
FROM INSTANCEOF java.lang.Object t 
WHERE toHex(t.@objectAddress)>="0x780000000" AND toHex(t.@objectAddress)<="0x7d5560000"
  • 注: 上面oql语句条件中的objectAddress中的值是通过vjmap工具输出信息中的PSOldGen得出的,记得使用时要删除0x后面的00000;
  • 上图中的shallow Heap是指对象在没有引用其它对象、数组时,对象本身的大小;
  • 上图中的Retained Heap是指对象本身的大小+它所引用对象的大小,即对象的shallow Heap+该对象所引用的所有对象大小的总和,即GC要回收该对象的内存大小

到这一步,剩下的工作就是分析上图所列出的对象,分析其GC路径和引用路径,分析程序中产生内存泄露的代码了;

这篇关于JVM-使用MAT(Memory Analyzer Tool)内存分析工具分析JVM老生代增长异常的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/540684

相关文章

使用Python创建一个功能完整的Windows风格计算器程序

《使用Python创建一个功能完整的Windows风格计算器程序》:本文主要介绍如何使用Python和Tkinter创建一个功能完整的Windows风格计算器程序,包括基本运算、高级科学计算(如三... 目录python实现Windows系统计算器程序(含高级功能)1. 使用Tkinter实现基础计算器2.

SpringBoot中四种AOP实战应用场景及代码实现

《SpringBoot中四种AOP实战应用场景及代码实现》面向切面编程(AOP)是Spring框架的核心功能之一,它通过预编译和运行期动态代理实现程序功能的统一维护,在SpringBoot应用中,AO... 目录引言场景一:日志记录与性能监控业务需求实现方案使用示例扩展:MDC实现请求跟踪场景二:权限控制与

在.NET平台使用C#为PDF添加各种类型的表单域的方法

《在.NET平台使用C#为PDF添加各种类型的表单域的方法》在日常办公系统开发中,涉及PDF处理相关的开发时,生成可填写的PDF表单是一种常见需求,与静态PDF不同,带有**表单域的文档支持用户直接在... 目录引言使用 PdfTextBoxField 添加文本输入域使用 PdfComboBoxField

慢sql提前分析预警和动态sql替换-Mybatis-SQL

《慢sql提前分析预警和动态sql替换-Mybatis-SQL》为防止慢SQL问题而开发的MyBatis组件,该组件能够在开发、测试阶段自动分析SQL语句,并在出现慢SQL问题时通过Ducc配置实现动... 目录背景解决思路开源方案调研设计方案详细设计使用方法1、引入依赖jar包2、配置组件XML3、核心配

Git可视化管理工具(SourceTree)使用操作大全经典

《Git可视化管理工具(SourceTree)使用操作大全经典》本文详细介绍了SourceTree作为Git可视化管理工具的常用操作,包括连接远程仓库、添加SSH密钥、克隆仓库、设置默认项目目录、代码... 目录前言:连接Gitee or github,获取代码:在SourceTree中添加SSH密钥:Cl

Java NoClassDefFoundError运行时错误分析解决

《JavaNoClassDefFoundError运行时错误分析解决》在Java开发中,NoClassDefFoundError是一种常见的运行时错误,它通常表明Java虚拟机在尝试加载一个类时未能... 目录前言一、问题分析二、报错原因三、解决思路检查类路径配置检查依赖库检查类文件调试类加载器问题四、常见

Java注解之超越Javadoc的元数据利器详解

《Java注解之超越Javadoc的元数据利器详解》本文将深入探讨Java注解的定义、类型、内置注解、自定义注解、保留策略、实际应用场景及最佳实践,无论是初学者还是资深开发者,都能通过本文了解如何利用... 目录什么是注解?注解的类型内置注编程解自定义注解注解的保留策略实际用例最佳实践总结在 Java 编程

Python中模块graphviz使用入门

《Python中模块graphviz使用入门》graphviz是一个用于创建和操作图形的Python库,本文主要介绍了Python中模块graphviz使用入门,具有一定的参考价值,感兴趣的可以了解一... 目录1.安装2. 基本用法2.1 输出图像格式2.2 图像style设置2.3 属性2.4 子图和聚

windows和Linux使用命令行计算文件的MD5值

《windows和Linux使用命令行计算文件的MD5值》在Windows和Linux系统中,您可以使用命令行(终端或命令提示符)来计算文件的MD5值,文章介绍了在Windows和Linux/macO... 目录在Windows上:在linux或MACOS上:总结在Windows上:可以使用certuti

CentOS和Ubuntu系统使用shell脚本创建用户和设置密码

《CentOS和Ubuntu系统使用shell脚本创建用户和设置密码》在Linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设置密码,本文写了一个shell... 在linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设