MAT定位OOM溢出源

前期准备:

配置oom自动dump jvm快照:-XX :+HeapDumpOnOutOfMemoryError

分析过程:

1)MAT中导入java_pid17932.hprof jvm快照,查看histogram 信息

注:Shallow Heap:对象自身不包含引用的大小;Retained Heap:对象自身及对象相关引用的大小

结论:如图,可得出每个类产生的实例数量(Objects栏),以及所占用的内存大小。从而能定位到占用内存最多的几个类

2)分析GCRoot引用(选中大类,右击)

注:GC Roots意为GC根节点,其中 exclude all phantom/weak/soft etc. reference 意思是排除虚引用、弱引用和软引用,即只剩下强引用,因为除了强引用之外,其他的引用都可以被JVM GC掉,如果一个对象始终无法被GC,就说明有强引用存在,从而导致在GC的过程中一直得不到回收,最终就内存溢出了。

3)结合日志oom报错定位代码块

结论:可以很方便的定位到具体的代码,然后分析是什么原因无法释放该对象。

这里是在OOMTest类里写了个list.add死循环,在list扩容方法时堆内存不够导致内存溢出。

总结

1.histhistogram找到占用多的类

2.只看强yiny引用,对象的gcroot 定位到哪个对象没被gc

3.结合报错日志,定位具体代码

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值