使用MAT定位线上OOM问题

目录

1.什么是OOM?

2.发生的可能原因

3.常见类型的OOM

4.如何定位问题?

[4.1 获取dump文件](#4.1 获取dump文件)

[4.2 MAT分析](#4.2 MAT分析)

[「Leak Suspects」泄露嫌疑](#「Leak Suspects」泄露嫌疑)

「Histogram」直方图

[「dominator tree」支配树](#「dominator tree」支配树)

[「thread overview」线程视图](#「thread overview」线程视图)


目录

1.什么是OOM?

2.发生的可能原因

3.OOM类型

4.如何定位问题?

[4.1 获取dump文件](#4.1 获取dump文件)

[4.2 MAT分析](#4.2 MAT分析)


1.什么是OOM?

OOM,全称"Out Of Memory",就是"内存用完了"。当JVM因为没有足够的内存来为对象分配空间并且垃圾回收器也已经没有空间可回收时,就会抛出这个error

2.发生的可能原因

  • 内存溢出:一次性申请的太多对象
  • 内存泄露:对象使用完一直未释放的,导致虚拟机不能再次使用该内存,此时这段内存就泄露了,因为申请者不用了,而又不能被虚拟机分配给别人用。
  • 本身资源不够(jmap -heap查看堆信息)分配的内存太小

3.常见类型的OOM

常见的有以下两种:

  • java.lang.OutOfMemoryError: Java heap space ------>java堆内存溢出
  • java.lang.OutOfMemoryError: PermGen space ------>java永久代溢出

4.如何定位问题?

4.1 获取dump文件

  • 系统已经OOM挂了

运行参数提前设置:

bash 复制代码
-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/export/Logs/project.hprof
  • 系统运行中还未OOM

执行以下命令导出dump文件:

bash 复制代码
> jps
> jmap -dump:format=b,file=project.hprof ${pid}

4.2 MAT分析

「Leak Suspects」泄露嫌疑
「Histogram」直方图

显示了各个类的内存占用情况,按照对象的数量或大小进行排序。可以在 Window - Preferences 菜单中设置单位

  • Shallow heap:指的是对象自身所占据的内存,不包含对其他对象的引用,也就是对象头加成员变量(不是成员变量的值)的总和。

  • Retained heap:指的是该对象GC之后所能回收的总和,包括对象自身所占据的内存,加上仅能够通过该对象引用到的其他对象所占据的内存。

把内存中的对象看成下图中的节点,并且对象和对象之间互相引用。这里有一个特殊的节点GC Roots,这就是reference chain的起点

从obj1入手,上图中蓝色节点代表仅仅只有通过obj1才能直接或间接访问的对象。因为可以通过GC Roots访问,所以左图的obj3不是蓝色节点;而在右图却是蓝色,因为它已经被包含在retained集合内。所以对于左图,obj1的retained size是obj1、obj2、obj4的shallow size总和;右图的retained size是obj1、obj2、obj3、obj4的shallow size总和。obj2的retained size可以通过相同的方式计算

对象引用关系

  • with incoming references 表示的是当前查看的对象,被外部应用
  • with outGoing references 表示的是当前对象,引用了外部对象
「dominator tree」支配树

在此视图中列出了每个对象(Object Instance)与其引用关系的树状结构,同时包含了占用内存的大小和百分比。

「thread overview」线程视图
相关推荐
自由鬼16 分钟前
正向代理服务器Squid:功能、架构、部署与应用深度解析
java·运维·服务器·程序人生·安全·架构·代理
许白掰22 分钟前
Linux入门篇学习——Linux 编写第一个自己的命令
linux·运维·数据库·嵌入式硬件·学习
打不了嗝 ᥬ᭄28 分钟前
文件系统----底层架构
linux·运维·数据库
cui_win42 分钟前
【网络】Linux 内核优化实战 - net.ipv4.tcp_keepalive_time
linux·网络·tcp/ip
fouryears_234171 小时前
深入拆解Spring核心思想之一:IoC
java·后端·spring
codervibe1 小时前
使用 Spring Boot + JWT 实现多角色登录认证(附完整流程图)
java·后端
kfepiza1 小时前
Linux创建网桥Bridge的方法有哪些? 笔记250710
linux·tcp/ip
坚持学习永不言弃1 小时前
Ehcache、Caffeine、Memcached和Redis缓存
java
大白的编程日记.1 小时前
【计算机基础理论知识】C++篇(二)
开发语言·c++·学习
阿劲1 小时前
从业务卡顿到数据库连接池耗尽:Spring Boot项目HikariCP超时问题实战排查
java·后端·面试