问题描述
我使用的是 Java 11 和 G1GC。我正在处理的应用程序是一个大数据应用程序,我注意到的奇怪的事情是我正在监视应用程序 24 小时,并且没有重大 GC。但是 Old gen 的大小会周期性地一次又一次地减小,而且巧合的是,当次要 GC 在同一分钟内花费大量时间时,就会发生这种情况。
我不明白为什么 Minor GC 上的峰值会清除 Old gen 中的数据。
解决方法
G1 GC 也有混合 GC 的概念,这给了 G1 GC 的名字 - 垃圾优先。在这次GC中,年轻代以及Old空间中包含最多垃圾的一些区域被清理干净,即Garbage First。这种机制允许 G1 GC 尝试尽可能长时间地避免 Full GC。由于 full GC 主要负责与垃圾收集相关的长时间暂停,因此 G1 GC 能够最大限度地减少对这些昂贵操作的需求。