美文网首页
Java垃圾回收器(二)

Java垃圾回收器(二)

作者: taoguan | 来源:发表于2019-10-25 22:01 被阅读0次

    垃圾收集器组合

    JDK7/8后,HotSpot虚拟机所有收集器及组合(连线),如下图:


    image
    • 图中展示了7种不同分代的收集器:
      Serial、ParNew、Parallel Scavenge、Serial Old、Parallel Old、CMS、G1;

    • 而它们所处区域,则表明其是属于新生代收集器还是老年代收集器:
      新生代收集器:Serial、ParNew、Parallel Scavenge;
      老年代收集器:Serial Old、Parallel Old、CMS;
      整堆收集器:G1;

    • 两个收集器间有连线,表明它们可以搭配使用

    • 其中Serial Old作为CMS出现"Concurrent Mode Failure"失败的后备预案

    Parallel Scavenge收集器

    Parallel Scavenge垃圾收集器因为与吞吐量关系密切,也称为吞吐量收集器(Throughput Collector)。

    1、特点

    新生代收集器;
    采用复制算法;
    多线程收集;
    目标是达一个可控制的吞吐量(Throughput)

    2、应用场景

    高吞吐量为目标,即减少垃圾收集时间,让用户代码获得更长的运行时间;
    当应用程序运行在具有多个CPU上,对暂停时间没有特别高的要求时,即程序主要在后台进行计算,而不需要与用户进行太多交互;

    3、设置参数

    (1)"-XX:MaxGCPauseMillis"
    控制最大垃圾收集停顿时间,大于0的毫秒数;
    MaxGCPauseMillis设置得稍小,停顿时间可能会缩短,但也可能会使得吞吐量下降,因为可能导致垃圾收集发生得更频繁;
    (2)"-XX:GCTimeRatio"
    设置垃圾收集时间占总时间的比率,0<n<100的整数;
    GCTimeRatio相当于设置吞吐量大小;
    垃圾收集执行时间占应用程序执行时间的比例的计算方法是:
    1 / (1 + n)
    例如,选项-XX:GCTimeRatio=19,设置了垃圾收集时间占总时间的5%--1/(1+19);
    默认值是1%--1/(1+99),即n=99;
    (3)"-XX:+UseAdptiveSizePolicy"
    开启这个参数后,就不用手工指定一些细节参数,如:
    新生代的大小(-Xmn)、Eden与Survivor区的比例(-XX:SurvivorRation)、晋升老年代的对象年龄(-XX:PretenureSizeThreshold)等;
    JVM会根据当前系统运行情况收集性能监控信息,动态调整这些参数,以提供最合适的停顿时间或最大的吞吐量,这种调节方式称为GC自适应的调节策略(GC Ergonomiscs)

    这是一种值得推荐的方式
    (1)、只需设置好内存数据大小(如"-Xmx"设置最大堆);
    (2)、然后使用"-XX:MaxGCPauseMillis"或"-XX:GCTimeRatio"给JVM设置一个优化目标;
    (3)、那些具体细节参数的调节就由JVM自适应完成;
    这也是Parallel Scavenge收集器与ParNew收集器一个重要区别;

    Serial Old收集器

    Serial Old是 Serial收集器的老年代版本

    1、特点

    针对老年代;
    采用"标记-整理"算法(还有压缩,Mark-Sweep-Compact);
    单线程收集;
    Serial/Serial Old收集器运行示意图如下:


    image

    2、应用场景

    主要用于Client模式;
    在Server模式有两大用途:

    • 在JDK1.5及之前,与Parallel Scavenge收集器搭配使用(JDK1.6有Parallel Old收集器可搭配);
    • 作为CMS收集器的后备预案,在并发收集发生Concurrent Mode Failure时使用;

    相关文章

      网友评论

          本文标题:Java垃圾回收器(二)

          本文链接:https://www.haomeiwen.com/subject/krbevctx.html