jvmGC回收器

串行收集器:
启动方式:-XX:UseSerialGC
使用该模式后eden使用复制算法,old代使用标记-压缩

ParNeW并行收集器:
启动方式: -XX:+UseParNewGC
使用该模式后,eden代使用并行回收,old代使用串行回收
同时可以使用-XX:ParallelGCThread限制并行回收线程数量

Parallel收集器:
1.ParNew的升级版本
2.该收集器下 eden代使用复制算法 old代使用标记-压缩算法
3.-XX:+UseParallelGC eden使用Parallel并行 old代使用串行收集
4.-XX:+UseParallelOldGC eden+old都使用parallel并行收集

并行收集器参数:
-XX:MaxGCPauseMills 最大停顿时间,GC过程中尽量不超过改时间(不保证一定)
-XX:GCTimeRatio 程序运行时间和GC时间比例 默认99

CMS收集器:
1.Concurrent Mark Sweep 并发标记-清除算法
2.是和应用程序并发执行的一种收集器
3.使用在old代的回收,eden仍代使用ParNew
4.启用方式:-XX:+UseConcMarkSweepGC
5.执行过程A初始标记->B并发标记->C重新标记->D并发清理.在A,C阶段依然可能出现STW
6.-XX:CMSInitiatingOccupancyFraction 设置触法GC的阈值
  -XX:+ UseCMSCompactAtFullCollection Full GC后,进行一次整理
  -XX:+CMSFullGCsBeforeCompaction 设置进行几次FullGC后,进行碎片整理
  -XX:ParallelCMSThreads 设定CMS的线程数量
7.CMS回收启动失败,会使用串行收集器进行GC

GC参数整理:
-XX:+UseSerialGC:在新生代和老年代使用串行收集器
-XX:SurvivorRatio:设置eden区大小和survivior区大小的比例
-XX:NewRatio:新生代和老年代的比
-XX:+UseParNewGC:在新生代使用并行收集器
-XX:+UseParallelGC :新生代使用并行回收收集器
-XX:+UseParallelOldGC:老年代使用并行回收收集器
-XX:ParallelGCThreads:设置用于垃圾回收的线程数
-XX:+UseConcMarkSweepGC:新生代使用并行收集器,老年代使用CMS+串行收集器
-XX:ParallelCMSThreads:设定CMS的线程数量
-XX:CMSInitiatingOccupancyFraction:设置CMS收集器在老年代空间被使用多少后触发
-XX:+UseCMSCompactAtFullCollection:设置CMS收集器在完成垃圾收集后是否要进行一次内    存碎片的整理
-XX:CMSFullGCsBeforeCompaction:设定进行多少次CMS垃圾回收后,进行一次内存压缩
-XX:+CMSClassUnloadingEnabled:允许对类元数据进行回收
-XX:CMSInitiatingPermOccupancyFraction当永久区占用率达到这一百分比时,启动CMS回收
-XX:UseCMSInitiatingOccupancyOnly:表示只在到达阀值的时候,才进行CMS回收


你可能感兴趣的:(jvm)