一、ParNewGC
按照上篇,开启ParNewGC后,老年代GC使用的收集器应该是SerialOldGC,通过arthas工具dashboard命令监控,可以看到下图。
图1-1
老年代GC使用的算法是gc.marksweepcompact
二、疑惑
使用以下jvm参数:-XX:+UseParallelGC -XX:+UseConcMarkSweepGC后,arthas中监控老年代使用的GC算法仍然是gc.marksweepcompact。
三、解答
Serial Old是Serial收集器的老年代版本,也属于单线程串行收集器,采用的算法为Mark-Compact(标记-整理算法)。
与用于新生代的Serial收集器“复制算法”不同。标记-整理算法可以简单认为是标记-清除算法和复制算法的组合。
CMS GC的后备方案是Serial Old GC,CMS什么情况下会退化为serialOld?
在并发清理过程中,如果不断有新生代对象被晋升到老年代的预留空间中,并且老年代产生大量的浮动垃圾的时候。导致了老年代空间紧张。这时候CMS就会退化为serialOld收集器。serialOld工作时会暂停所有的用户线程,单线程进行老年代的垃圾回收。所以这样也会降低垃圾收集的效率,STW时间延长。这也是CMS的一个缺陷之一。