JVM垃圾收集器的搭配

JDK1.5及之前的JDK上:


如果jvm运行在client上:
1.若为单核CPU:新生代使用Serial,老年代使用Serial Old

2.若为多核CPU:新生代使用ParNew,老年代使用CMS(硬件比较高级的情况下,如果普通的双核cpu甚至不如serial+serial old)

如果jvm运行在server上:

1.若注重吞吐量(比如执行的多为后台计算这种任务):新生代使用Parallel Scavenge收集器,老年代使用Serial Old收集器

2.若注重交互和响应时间:

  
(1)单核:新生代使用serial,老年代使用CMS

(2)多核cpu/多cpu:新生代使用ParNew,老年代使用CMS

JDK1.6之后发布的Parallel Old收集器与Parallel收集器一起使用可以达到较好的吞吐量,其余同jdk1.5及之前的版本


垃圾收集器特征整理:

1.Serial收集器:Serial收集器是一个单线程的新生代收集器,到目前仍然是client模式下的默认新生代收集器

2.Serial Old收集器:Serial Old收集器是单线程的老年代收集器,目前也是client模式下的默认老年代收集器

3.ParNew收集器:Par New收集器是Serial的多线程版本,除了单线程收集器Serial外,目前只有该收集器可以与CMS收集器一起工作

4.Parallel Scavenge收集器:Parallel Scavenge收集器是一个多线程的新生代收集器,它与ParNew的不同之处在于该收集器更注重吞吐量而不是更短的停顿时间

5.Parallel Old收集器:该收集器是Parallel Scavenge收集器的老年代版本,在jdk1.6之后才提供,用以代替jdk1.5及之前的Parallen Scavenge+Serial Old的尴尬组合(Parallel Scavenge收集器无法与CMS一起工作)

6.CMS收集器:jdk1.5时发布的一个老年代收集器,因其停顿时间很短,很符合强交互应用的要求,但只能与Serial收集器、ParNew收集器搭配工作,不能与Parallel Scavenge一起工作

7.再往后的G1收集器理论上可以达到更短的停顿时间,并且不分新生代老年代,但尚未在大规模应用中经受过考验,若个人使用追求更短的停顿时间可以尝试,不建议在生产环境中使用

你可能感兴趣的:(JVM)