JVM垃圾回收——垃圾收集器(一)

目录

一、垃圾收集器

二、Serial/Serial Old

三、ParNew 收集器

四、Parallel Scavenge收集器

五、Parallel Old收集器


一、垃圾收集器

 现阶段可以作为商用的垃圾收集器大概以上几种,ZGC还正在实验阶段,如果两个收集器之间有连线那么表示他们可搭配使用。在jdk8中已经废弃了Serial+CMS和ParNew+Serial Old这两个组合。在jdk9之后已经完全取消了这些组合的支持。

在jdk17下,配置了这两组垃圾收集器,在启动时候报错找不到参数,如下图

 本系列将分四个部分讲解,首先分析几种传统的垃圾收集器,然后分析CMS垃圾收集器(虽然CMS收集器已经被G1完全取代,在jdk14之后也抛弃了CMS),再分析一下G1垃圾收集器,最后说一下ZGC。

二、Serial/Serial Old

        serial 垃圾收集器在jdk1.3.1之前是HotSpot垃圾收集唯一收集器。他是一个单线程工作的收集器。基于复制算法实现,在进行垃圾收集时必须暂停用户线程进行STW(stop the world)。主要用在Hotspot虚拟机运行在客户端模式下默认的新生代垃圾收集器,由于是单线程的工作模式,不存在线程切换,没有线程交互的开销,在收集几十到一两百兆的新生代效率还是很不错的。

        Serial Old 是Serial收集器的老年代收集版本,也是一个单线程的收集器,使用标记整理算法实现。主要也是适用于客户端模式下老年代的垃圾收集。在服务端模式下主要有两点作用,在jdk5之前与Parallel Scavenge收集器搭配使用,第二个是在CMS收集器发生Concurrent Mode Failure时使用。

        JVM 参数配置  -XX:+UseSerialGC 没有-XX:+UseSerialOldGC参数

三、ParNew 收集器

        ParNew收集器实际上是Serial的多线程并行版本。除了使用多线程之外,其他行为包括收集算法,STW、对象分配规则、回收策略等都与Serial完全一致。但是在JDK9之后,JVM已经取消了-XX:+UseParNewGC ,参数ParNew合并入CMS收集器,在配置该参数时会报Unrecognized VM option 'UseParNewGC'错误。在jdk9之前是唯一推荐和CMS垃圾收集器配合的收集器,如果老年代使用CMS垃圾收集器,那么新生代收集器默认是ParNew。

        在使用CMS垃圾收集器时,-XX:MaxTenuringThreshold=6默认值是6,使用以下参数可以打印出垃圾收集器的明细

-XX:+UseConcMarkSweepGC
-XX:MaxTenuringThreshold=15
-XX:+PrintCommandLineFlags

显示结果为

 使用 -XX:ParallelGCThreads 参数可以限制垃圾收集的线程数。

四、Parallel Scavenge收集器

        Parallel Scavenge收集器是一款新生代的收集器,基于标记复制算法实现的,它在很多方面和ParNew非常相似,是一个多线程并行的垃圾搜集器。不像CMS一样关注停顿时间,该收集器更关注的是吞吐量(Throughput)。

        Parallel Scavenge 收集器有几个JVM需要关注一下

  • -XX:MaxGCPauseMillis=200 表示垃圾收集最大的停顿时间,jvm会尽量在不超过这个设定的时间范围内完成垃圾收集。这是一个大于0的毫秒数,但并不是这个数值设置的越小越好,它是以牺牲新生代内存大小为代价的,如果时间设置的越小,那么新生代对应的内存空间就会变小,垃圾收集停顿时间减少,但是垃圾收集次数变多。
  • -XX:GCTimeRatio 表示用户期望虚拟机消耗在GC上的时间不超过程序运行时间的1/1+n。默认值为99,也就是吞吐量。
  • -XX:+UseAdaptiveSizePolicy 当这个参数被激活后,不需要人为的指定新生代的大小(-Xmn)、Eden和Survivor 的比例(-XX:survivorRatio)、晋升到年代对象大小(-XX:PretenureSize Threshold)等参数了。JVM会动态调整这些参数。

        开启Parallel Scavenge垃圾收集器的参数配置如下,默认使用ParallelOldGC时候默认新生代使用的是ParallelScavenge收集器。

-XX:+UseParallelOldGC
-XX:+UseAdaptiveSizePolicy
-XX:MaxGCPauseMillis=200
-XX:+PrintCommandLineFlags

五、Parallel Old收集器

        Parallel Old 是ParallelScavenge收集器的老年代收集版本,也是一个多线程并行的垃圾收集器,基于标志整理算法实现。

Parallel Old收集器工作过程示意图

 

        由于Parallel Scavenge关注吞吐量,所以在注重吞吐量或者处理器资源(CPU)较为稀缺的场景,可以优先考虑Parallel Scavenge + Parallel Old的组合。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

熟透的蜗牛

永远满怀热爱,永远热泪盈眶

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值