测试帮日记-小强测试品牌旗下

JVM内存泄露(OOM)!带你一一揭秘【第二弹】

2020-03-25 22:36:00    testingbang    975    原创

点击链接加入群138269539(全国招聘信息、免费公开课、视频应有尽有):https://jq.qq.com/?_wv=1027&k=5q0IklJ 更多内容可以关注公众号:测试帮日记

我们将分成多次介绍内存泄露OOM的内容,大致套路为现象、原因、解决方案。简单清晰,不玩高大上。记得给转发一下,哈哈


OOM最典型的表现:java.lang.OutOfMemoryError,你记住了吗?


回顾:JVM内存泄露(OOM)!带你一一揭秘【第一弹】


1 OOM的现象之二

今天介绍第二种GC overhead limit exceeded


2 什么原因造成的?

1)应用程序已经耗尽了几乎所有的可用内存并且GC一直未能回收它


2)官方解释:JVM花费了98%的时间进行垃圾回收,而只得到2%可用的内存,频繁的进行内存回收(最起码已经进行了5次连续的垃圾回收),JVM就会曝出ava.lang.OutOfMemoryError: GC overhead limit exceeded错误。


3 怎么解决和避免呢?

1)增加heap堆内存


2)考虑使用G1GC垃圾回收算法


3)千万不要使用-XX:-UseGCOverheadLimit


4)最根本的你还是要找出来哪些对象占据堆的大部分,这些对象在源代码中的什么地方


好了,今天就到这里,第三弹明天见面~