MAT查找类(岔路口)-技巧

文章目录

  • 前言
  • 一、现状
  • 二、使用步骤
    • 1.导出 hprof
    • 2.用MAT打开
    • 3.细节操作
      • 找大对象的线程名称
      • 查看线程的详情
      • 查找类的GC Roots
      • 柳暗花明
      • 检验真理
  • 总结


前言

又是java 内存溢出 OOM
JAVA MAT 分析工具大大的好。
高效查找问题根源,才是硬道理。


一、现状

  1. mat 打开hprof 文件,可以一眼看到内存占用最多的类。
  2. 但是这个类并不是我自己创建的类。
  3. 怎么确定这个类和我的业务流程是有关联呢。
  4. 那就是找到这个类在业务流程的入口(岔路口)。

二、使用步骤

1.导出 hprof

命令如下

jmap -dump:live,format=b,file=dumextra05.hprof  486424

2.用MAT打开

一眼望去,简单明了,就是你:ResultSetImpl, 就是你占的最多。
在这里插入图片描述

3.细节操作

找大对象的线程名称

左上箭头(dominator_tree)点一下,找到第一行(默认第一个占用最大)右击
看图
在这里插入图片描述
接下来就看到线程名字如下:
在这里插入图片描述

查看线程的详情

左上小黄轮(thread_overview)点击,找到线程名称。
在这里插入图片描述
右击->点击[Thread Details]
在这里插入图片描述
看到详情,这个界面看着比较顺眼(java 报错信息也是像这种一片红)
其中有个类是我自己定义的,说明这个大内存对象和我的业务流程是有点联系(还需继续确认)。
在这里插入图片描述

查找类的GC Roots

回到dominator_tree界面,在第一列最上方有个搜索框,输入自己的业务类“ExcelExportSqlStreamHandle”,回车
在这里插入图片描述
右键点击第二行(前面有 class 开头)
在这里插入图片描述
到如下界面,全部展开,对我们有用的信息其实就是前面几行,到有线程名称(蓝色)那行。
这里没有大内存对象(ResultSetImpl), 无法判断内存超载是和我们的业务流程有联系。
还得继续操作。
在这里插入图片描述

柳暗花明

回到dominator_tree,如上刚才操作查看 “ResultSetImpl”的GC Roots信息

在这里插入图片描述
然后就是眼力对比(目前我只能这么做)
根据耐心 + 眼力, 隐约浮现一个类 “PreparedStatementHandler”。
此类双方都存在,且下一行的线程名称(黄箭头)都是一样。
所有我敢保证此类就是传说中的岔路口
在这里插入图片描述

检验真理

使用 IDEA debugger 模式运行
在“ResultSetImpl” 所有构造方法打断点(因为我也不知道进哪个)。
果然鱼上钩了,程序进来了。
看左下线程栈,有“PreparedStatementHandler”
在这里插入图片描述
在自己的业务类“ExcelExportSqlStreamHandle”的业务方法也打断点。
左下线程栈也有“PreparedStatementHandler”
在这里插入图片描述
点击“PreparedStatementHandler”查看:
execute 那行代码进去之后就是引起大内存对象产生,实际执行的就是mybatis 查询,我的业务流程就是查询很多条数据。
handleCursorResultSets 那行代码就是进到我自己的业务流程,这里的 resultSetHandler 就是我的业务类ExcelExportSqlStreamHandle 的父类。
分别从上一行(黄箭头)也能看出来,下一步是什么方法
在这里插入图片描述


总结

多实践。
之前很少用MAT,本来不是很熟悉,花了一天各种点点,摸索出来这种查找技巧。


—————— 但行好事莫问前程,你若盛开蝴蝶自来

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/160822.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

CVE-2017-7529 Nginx越界读取内存漏洞

漏洞概述 当使用Nginx标准模块时,攻击者可以通过发送包含恶意构造range域的header请求,来获取响应中的缓存文件头部信息。在某些配置中,缓存文件头可能包含后端服务器的IP地址或其它敏感信息,从而导致信息泄露。 影响版本 Ngin…

vue3后台管理框架之技术栈

vue3全家桶技术 基础构建: vue3vite4TypeScript 代码格式 : eslintprettystylelint git生命周期钩子: husky css预处理器: sass ui库: element-plus 模拟数据: mock 网络请求: axios 路由: vue…

Three.js图案溶解shader

上图提供两种方式溶解显示 上面一排是根据现实的图案红色通道也就是r值进行溶解 下面一排提供额外的溶解纹理 可以通过简单更改呈现多种溶解图案 代码仓库 gitee b站账号:https://space.bilibili.com/374230437 interface IMapPath {map: string;dissolve?: string…

基于antd实现动态修改节点的Tree组件

前言 之前遇到一个需求,可对于任意节点添加或删除子节点。首先技术栈是基于reactant design,ant提供了Tree组件,但都是根据固定的数据渲染出树结构,如果需要新增或删除节点,官网并未提供。 实现过程 新增节点 首先…

910数据结构(2013年真题)

算法设计题 问题1 已知元素数据类型为整数的顺序表SL(a1,a2,…,am,b1,b2,…,bn),试设计算法将SL中元素的两部分互换为(b1,b2,…,bn,a1,a2,…,am)。要求:不能使用额外的数组空间。 (1&#xff…

使用 Python 和蒙特卡罗计算未来股价走势以及历史波动率和隐含波动率

一、简介 预测金融市场是定量精度和全球经济细微差别的复杂融合。在这一探索中,蒙特卡罗模拟脱颖而出,成为首要的统计工具,指导我们对未来股票价格的理解。 这种方法以摩纳哥著名的蒙特卡洛赌场命名,并不依靠运气,而是植根于严格的概率模型。想象一下在受控环境中精心策划…

前端开发工具有哪些?17款前端工程师必备工具推荐!

软件开发是一个高度专业化的职业分工,根据所使用的编程语言的不同,会细分出多种岗位:前端开发、后端开发、客户端开发、iOS开发、Android开发、数据库开发等等,具体到每一个岗位,工作中常用的工具软件也存在着差别。 …

0基础学习VR全景平台篇 第108篇:全景图细节处理(下,航拍)

上课!全体起立~ 大家好,欢迎观看蛙色官方系列全景摄影课程! (调色前图库) (原图-大图) 一、导入文件 单击右下角导入按钮,选择航拍图片所在文件夹,选择图片&#xff0…

【前端】Js

目 录 一.前置知识第一个程序JavaScript 的书写形式注释输入输出 二.语法概览变量的使用理解 动态类型基本数据类型 三.运算符算术运算符赋值运算符 & 复合赋值运算符自增自减运算符比较运算符逻辑运算符位运算移位运算 四.条件语句if 语句三元表达式switch 五.循环语句whi…

基于php 进行每半小时钉钉预警

前言 业务场景:监控当前业务当出现并发情况时技术人员可以可以及时处理 使用技术栈: laravelredis 半小时触发一次报警信息实现思路 1、xshell脚本 具体参数就不详细解释了,想要详细了解可以自行百度 curl -H "Content-Type:appl…

论文阅读/写作扫盲

第一节:期刊科普 JCR分区和中科院分区是用于对期刊进行分类和评估的两种常见方法。它们的存在是为了帮助学术界和研究人员更好地了解期刊的学术质量、影响力和地位。 JCR分区(Journal Citation Reports):JCR分区是由Clarivate Ana…

有哪些值得推荐的优秀 HTMLCSS 网站前端设计的网络资源(博客、论坛)?

前言 推荐几个有意思的CSS学习的网站和github上的学习类型的项目~ 网站推荐 1、CODEPEN 代码与所展示的页面相互对应,你可以在上面找到其他人已经写好的demo,参考 代码效果 网址:https://codepen.io 2、Coding Fantasy 通过游戏的形式来提…

多媒体应用设计师 第7章 多媒体数字压缩编码技术基础

1.多媒体数据压缩技术理论基础及压缩编码方法分类 必要性:大数据量的图像信息会给存储器的存储容量,通信线路的带宽,以及计算机的处理速度增加极大压力。如果没有多媒体编码压缩技术的发展,大容量图像,视频信息的存储和传输就难以…

自助查询小助手

嘿亲爱的老师们!还在为成绩发布而烦恼吗?别担心,今天我们来聊聊如何利用免费的老师发布工具,让你轻松解决这一烦恼! 成绩查询页面是什么?在很多学校里,成绩查询页面通常是一个网站或应用程序&am…

list.set交换数据需要(or不需要)添加其他中间变量,两个例子告诉你

说明:set()方法是来修改指定位置的元素。 两个参数,第一个参数是要修改的元素的索引,第二个参数是要设置的新值。 案例一:当链表中传入的是字符串时: public static void main(String[] args) {List list new Linke…

自动驾驶:控制算法概述

自动驾驶:控制算法概述 常见控制算法PID算法LQR算法MPC算法 自动驾驶控制算法横向控制纵向控制 参考文献 常见控制算法 PID算法 PID(Proportional-Integral-Derivative)控制是一种经典的反馈控制算法,通常用于稳定性和响应速度要…

docker数据卷+挂载(命令讲解+示例)

在容器中管理数据主要有两种方式: 数据卷(Volumes) 、挂载主机目录 (Bind mounts)。 一、数据卷 数据卷是一个可供一个或多个容器使用的特殊目录,可以在容器之间共享和重用。 特点: 对 数据卷 的修改会立马生效对 …

docker-compose部署elk(8.9.0)并开启ssl认证

docker部署elk并开启ssl认证 docker-compose部署elk部署所需yml文件 —— docker-compose-elk.yml部署配置elasticsearch和kibana并开启ssl配置基础数据认证配置elasticsearch和kibana开启https访问 配置logstash创建springboot项目进行测试kibana创建视图,查询日志…

Spring5应用之高级注解开发

作者简介:☕️大家好,我是Aomsir,一个爱折腾的开发者! 个人主页:Aomsir_Spring5应用专栏,Netty应用专栏,RPC应用专栏-CSDN博客 当前专栏:Spring5应用专栏_Aomsir的博客-CSDN博客 文章目录 参考文献前言Conf…

那些年,我们追过的Java BUG

🌷🍁 博主猫头虎 带您 Go to New World.✨🍁 🦄 博客首页——猫头虎的博客🎐 🐳《面试题大全专栏》 文章图文并茂🦕生动形象🦖简单易学!欢迎大家来踩踩~🌺 &a…