堆内存划分为 Eden、Survivor 和 Tenured/Old 空间,如下图所示:
从年轻代空间(包括 Eden 和 Survivor 区域)回收内存被称为 Minor GC,对老年代GC称为Major GC,而Full GC是对整个堆来说的,在最近几个版本的JDK里默认包括了对永生带即方法区的回收(JDK8中无永生带了),出现Full GC的时候经常伴随至少一次的Minor GC,但非绝对的。Major GC的速度一般会比Minor GC慢10倍以上。下边看看有那种情况触发JVM进行Full GC及应对策略。
1、System.gc()方法的调用
此方法的调用是建议JVM进行Full GC,虽然只是建议而非一定,但很多情况下它会触发 Full GC,从而增加Full GC的频率,也即增加了间歇性停顿的次数。强烈影响系建议能不使用此方法就别使用,让虚拟机自己去管理它的内存,可通过通过-XX:+ DisableExplicitGC来禁止RMI

本文探讨了触发JVM Full GC的各种情况,包括老年代和永生区空间不足、CMS GC异常、Minor GC晋升问题以及大对象分配。针对这些问题,提出了相应的应对策略,如调整内存空间、禁用System.gc()调用、使用CMS GC和优化CMS参数,以减少Full GC的发生,提高系统性能。
最低0.47元/天 解锁文章
720

被折叠的 条评论
为什么被折叠?



