咨询QQ:2083503238、1684129674、480934277(请勿重复咨询) 咨询微信:qiangfans
JVM内存泄露(OOM)!带你一一揭秘【第二弹】
- 2020-03-25 22:36:00
- testingbang
- 原创 1161 投稿得红包
点击链接加入群138269539(全国招聘信息、免费公开课、视频应有尽有):https://jq.qq.com/?_wv=1027&k=5q0IklJ 更多内容可以关注公众号:测试帮日记
我们将分成多次介绍内存泄露OOM的内容,大致套路为现象、原因、解决方案。简单清晰,不玩高大上。记得给转发一下,哈哈
OOM最典型的表现:java.lang.OutOfMemoryError,你记住了吗?
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)最根本的你还是要找出来哪些对象占据堆的大部分,这些对象在源代码中的什么地方
好了,今天就到这里,第三弹明天见面~