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

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na