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

文章目录


前言

又是java 内存溢出 OOM

JAVA MAT 分析工具大大的好。

高效查找问题根源,才是硬道理。


一、现状

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

二、使用步骤

1.导出 hprof

命令如下

bash 复制代码
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,本来不是很熟悉,花了一天各种点点,摸索出来这种查找技巧。


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

相关推荐
桦说编程3 分钟前
Java 中如何创建不可变类型
java·后端·函数式编程
lifallen4 分钟前
Java Stream sort算子实现:SortedOps
java·开发语言
IT毕设实战小研6 分钟前
基于Spring Boot 4s店车辆管理系统 租车管理系统 停车位管理系统 智慧车辆管理系统
java·开发语言·spring boot·后端·spring·毕业设计·课程设计
没有bug.的程序员1 小时前
JVM 总览与运行原理:深入Java虚拟机的核心引擎
java·jvm·python·虚拟机
甄超锋1 小时前
Java ArrayList的介绍及用法
java·windows·spring boot·python·spring·spring cloud·tomcat
阿华的代码王国2 小时前
【Android】RecyclerView复用CheckBox的异常状态
android·xml·java·前端·后端
Zyy~2 小时前
《设计模式》装饰模式
java·设计模式
A尘埃2 小时前
企业级Java项目和大模型结合场景(智能客服系统:电商、金融、政务、企业)
java·金融·政务·智能客服系统
Jerry说前后端2 小时前
RecyclerView 性能优化:从原理到实践的深度优化方案
android·前端·性能优化
青云交2 小时前
Java 大视界 -- 基于 Java 的大数据可视化在城市交通拥堵治理与出行效率提升中的应用(398)
java·大数据·flink·大数据可视化·拥堵预测·城市交通治理·实时热力图