导航:首页 > 万维百科 > cms垃圾收集器

cms垃圾收集器

发布时间:2020-07-28 03:59:52

1、cms垃圾回收算法在gc过程中哪几个阶段会暂停应用县城

中间调整过几次,先搞了几台机器做了验证,后来逐步推广的。
1、调大heap区,由原来的4g,调整到5g,young区的大小不变,还是2g,这时候old区就由2g变为3g了(这样保证old区有足够的空间);
2、设置-XX:UseCMSInitiatingOccupancyOnly,其实这个不关这个问题,只是发现半夜CMS进行的有点频繁,就禁止掉了悲观策略;
3、设置CMS区回收的比例,从80%调整到75%,让old区尽早的进行,有足够的空间剩余;

为什么要有GC(垃圾回收)?

JVM通过GC来回收堆和方法区中的内存,GC的基本原理就是找到程序中不再被使用的对象,然后回收掉这些对象占用的内存。

主要的收集器有哪些?
引用计数器和跟踪计数器两种。
引用计数器记录对象是否被引用,当计数器为零时,说明对象已经不再被使用,可以进行回收。java中的对象有复杂的引用关系,不是很适合引用计数器,所以sun jdk中并没有实现这种GC方式。
跟踪收集器,全局记录数据的引用状态,基于一定的条件触发。执行的时候,从根集合开始扫描对象的引用关系,主要有复制(copying)、标记-清除(Mark-Sweep)、标记-压缩(Mark-Compact)那种算法。

2、jvm垃圾收集器为什么

JVM中垃圾的回收由垃圾收集器进行,随着JDK的不断升级,垃圾收集器也开发出了各种版本,垃圾收集器不断优化的动力,就是为了实现更短的停顿。

下面是7种不同的分代收集器,如果两个收集器之间有连线,则表示它们之间可以搭配使用;所处的区域表示属于新生代还是老年代收集器。

1.Serial 收集器 (新生代)

最基本、历史最悠久(JDK1.3.1之前),这是一个单线程的收集器,当该收集器运行时必须暂停其他所有的工作线程,直到它收集结束。

收集过程:暂停所有线程

算法:复制算法

优点:简单高效,拥有很高的单线程收集效率

应用:Client模式下的默认新生代收集器

2.ParNew 收集器 (新生代)

Serial 的多线程版本,使用多线程进行垃圾收集

收集过程:与用户线程并发

算法:复制算法

优点:在CPU多的情况下,拥有比Serial更好的效果。单CPU环境下Serial效果更好

应用:许多运行在Server模式下的虚拟机中首选的新生代收集器

3.Parallel Scavenge 收集器(新生代)

Parallel Scavenge收集器的目标是达到一个可控制的吞吐量

吞吐量 = 运行用户代码时间 / (运行用户代码时间 + 垃圾收集时间)

控制吞吐量的参数:最大垃圾收集停顿时间 -XX:MaxGCPauseMillis ; 直接设置吞吐量大小:-XX:GCTimeRatio。

MaxGCPauseMillis 的值为一个大于0的毫秒数, 最大停顿时间的缩短是以牺牲吞吐量和新生代空间来换取的。

GCTimeRatio 的值为一个大于0且小于100的整数。例如:-XX:GCTimeRatio=9 我们要求应用程序线程在整个执行时间中至少9/10是活动的(因此,GC线程占用其余1/10)

-XX:+UseAdaptiveSizePolicy:开启GC自适应调节策略,自动设置新生代大小、Eden与Survior区的比例、晋升老年代对象年龄等细节参数

应用:适合在后台运算而不需要太多交互的任务

4.Serial Old 收集器 (老年代)

Serial收集器的老年代版本,也是一个单线程的收集器,使用标记-整理算法

收集过程:暂停所有线程

算法:标记-整理算法

应用:主要意义是Client模式下的收集器,如果在Server模式下还有:a. JDK1.5之前的版本中与Parallel Scavenge搭配使用,b. 作为CMS收集器的后背预案在并发收集时使用

5. Parallel Old 收集器 (老年代)

Parallel Scavenge收集器的老年代版本,使用多线程和“标记-整理”算法。

收集过程:多线程

算法:标记-整理算法

应用:在注重吞吐量及CPU资源敏感的场合,可以优先考虑Parallel Scavenge加Parallel Old收集器

6. CMS 收集器 (老年代)

以获取最短回收停顿时间为目标,基于“标记-清除”算法

收集过程:初始标记-->并发标记-->重新标记-->并发清除

初始标记、重新标记两个步骤仍需要“Stop The World” : 初始标记仅仅只是标记一下GC
Roots能直接关联到的对象,速度很快;并发标记就是进行GC Roots
Tracing的过程;重新标记是为了修正并发标记期间因用户程序继续运作,而导致标记产生变动的那一部分对象的标记记录。

整个过程中耗时最长的是并发标记和并发清除,这两个过程都可以与用户线程一起工作。所以总体上说CMS收集器内存回收过程与用户线程一起并发执行。

算法:标记-清除 算法

缺点:1,对cpu资源敏感,默认启动的回收线程数是(cpu数量+3)/4,当cpu数较少的时候,会分掉大部分的cpu去执行收集器线程,影响用户,降低吞吐量。

2,无法处理浮动垃圾,浮动垃圾即在并发清除阶段因为是并发执行,还会产生垃圾,这一部分垃圾即为浮动垃圾,要等下次收集。

3,因为使用的是“标记-清除”算法,会产生碎片。

7. G1收集器 (整个Java堆:包括新生代和老年代)

特点:并行与并发、分代收集、空间整合、可预测的停顿

G1将整个java堆(包括新生代和老生代)划分为多个大小固定的独立区域,并跟踪这些区域的垃圾堆积程度,在后台维护一个优先列表,每次根据允许的收集时间,优先回收垃圾最多的区域。

但这样回收有一个问题:对象分配在某个区域中,但并非只被本区域的其他对象引用,而是可以与整个Java堆任意的对象发生引用关系。在做可达性分析的时候,如何避免扫描整个堆呢?

解决:区域之间的对象引用,以及其他收集器中新生代与老年代之间的对象引用,虚拟机都是使用Remembered Set来避免全堆扫描,在Remembered Set中记录对象的引用。

收集过程:初始标记-->并发标记-->最终标记-->筛选回收。与CMS不同的是,在最终标记阶段,需要停顿线程,但是可并发执行;筛选回收阶段,对各个区域的回收价值和成本进行排序,按照用户所期望的回收时间进行垃圾回收,这个阶段也可以并发执行。

3、cms垃圾回收算法在gc过程中哪几个阶段会暂停

Phase 1: Initial Mark(初始化标记)和 Phase 5: Final Remark(重新标记)这两个阶段会发生stop-the-world,暂停所有应用线程。

4、JVM的垃圾算法有哪几种

一、垃圾收集器概述

如上图所示,垃圾回收算法一共有7个,3个属于年轻代、三个属于年老代,G1属于横跨年轻代和年老代的算法。

JVM会从年轻代和年老代各选出一个算法进行组合,连线表示哪些算法可以组合使用

二、各个垃圾收集器说明

1、Serial(年轻代)

年轻代收集器,可以和Serial Old、CMS组合使用

采用复制算法

使用单线程进行垃圾回收,回收时会导致Stop The World,用户进程停止

client模式年轻代默认算法

GC日志关键字:DefNew(Default New Generation)

图示(Serial+Serial Old)

2、ParNew(年轻代)

新生代收集器,可以和Serial Old、CMS组合使用

采用复制算法

使用多线程进行垃圾回收,回收时会导致Stop The World,其它策略和Serial一样

server模式年轻代默认算法

使用-XX:ParallelGCthreads参数来限制垃圾回收的线程数

GC日志关键字:ParNew(Parallel New Generation)

图示(ParNew + Serail Old)

3、Paralle Scavenge(年轻代)

新生代收集器,可以和Serial Old、Parallel组合使用,不能和CMS组合使用

采用复制算法

使用多线程进行垃圾回收,回收时会导致Stop The World

关注系统吞吐量

-XX:MaxGCPauseMillis:设置大于0的毫秒数,收集器尽可能在该时间内完成垃圾回收

-XX:GCTimeRatio:大于0小于100的整数,即垃圾回收时间占总时间的比率,设置越小则希望垃圾回收所占时间越小,CPU能花更多的时间进行系统操作,提高吞吐量

-XX:UseAdaptiveSizePolicy:参数开关,启动后系统动态自适应调节各参数,如-Xmn、-XX:SurvivorRatio等参数,这是和ParNew收集器重要的区别

GC日志关键字:PSYoungGen

4、Serial Old(年老代)

年老代收集器,可以和所有的年轻代收集器组合使用(Serial收集器的年老代版本)

采用 ”标记-整理“算法,会对垃圾回收导致的内存碎片进行整理

使用单线程进行垃圾回收,回收时会导致Stop The World,用户进程停止

GC日志关键字:Tenured

图示(Serial+Serial Old)

5、Parallel Old(年老代)

年老代收集器,只能和Parallel Scavenge组合使用(Parallel Scavenge收集器的年老代版本)

采用 ”标记-整理“算法,会对垃圾回收导致的内存碎片进行整理

关注吞吐量的系统可以将Parallel Scavenge+Parallel Old组合使用

GC日志关键字:ParOldGen

图示(Parallel Scavenge+Parallel Old)

6、CMS(Concurrent Mark Sweep年老代)

年老代收集器,可以和Serial、ParNew组合使用

采用 ”标记-清除“算法,可以通过设置参数在垃圾回收时进行内存碎片的整理
1、:默认开启,FullGC时进行内存碎片整理,整理时用户进程需停止,即发生Stop The World
2、CMSFullGCsBeforeCompaction:设置执行多少次不压缩的Full GC后,执行一个带压缩的(默认为0,表示每次进入Full GC时都进行碎片整理)

CMS是并发算法,表示垃圾回收和用户进行同时进行,但是不是所有阶段都同时进行,在初始标记、重新标记阶段还是需要Stop the World。CMS垃圾回收分这四个阶段
1、初始标记(CMS Initial mark)  Stop the World 仅仅标记一下GC Roots能直接关联到的对象,速度快
2、并发标记(CMS concurrent mark) 进行GC Roots Tracing,时间长,不发生用户进程停顿
3、重新标记(CMS remark)  Stop the World 修正并发标记期间因用户程序继续运行导致标记变动的那一部分对象的标记记录,停顿时间较长,但远比并发标记时间短
4、并发清除(CMS concurrent sweep) 清除的同时用户进程会导致新的垃圾,时间长,不发生用户进程停顿

适合于对响应时间要求高的系统

GC日志关键字:CMS-initial-mark、CMS-concurrent-mark-start、CMS-concurrent-mark、CMS-concurrent-preclean-start、CMS-concurrent-preclean、CMS-concurrent-sweep、CMS-concurrent-reset等等

缺点
1、对CPU资源非常敏感
2、CMS收集器无法处理浮动垃圾,即清除时用户进程同时产生的垃圾,只能等到下次GC时回收
3、因为是使用“标记-清除”算法,所以会产生大量碎片

图示

7、G1

G1收集器由于没有使用过,所以从网上找了一些教程供大家了解

并行与并发

分代收集

空间整合

可预测的停顿

5、如何指定定java cms垃圾回收

如果你的JAVA应用程序有以下几个特点,那么可以使用Concurrent Mark Sweep (CMS) 垃圾收集器。
希望JAVA垃圾回收器回收垃圾的时间尽可能短;
应用运行在多CPU的机器上,有足够的CPU资源;
有比较多生命周期长的对象;
希望应用的响应时间短。

6、如何提高java虚拟机的垃圾收集器

Serial(串行GC)收集器
Serial收集器是一个新生代收集器,单线程执行,使用复制算法。它在进行垃圾收集时,必须暂停其他所有的工作线程(用户线程)。是Jvm client模式下默认的新生代收集器。对于限定单个CPU的环境来说,Serial收集器由于没有线程交互的开销,专心做垃圾收集自然可以获得最高的单线程收集效率。
ParNew(并行GC)收集器
ParNew收集器其实就是serial收集器的多线程版本,除了使用多条线程进行垃圾收集之外,其余行为与Serial收集器一样。
Parallel Scavenge(并行回收GC)收集器
Parallel Scavenge收集器也是一个新生代收集器,它也是使用复制算法的收集器,又是并行多线程收集器。parallel Scavenge收集器的特点是它的关注点与其他收集器不同,CMS等收集器的关注点是尽可能地缩短垃圾收集时用户线程的停顿时间,而parallel Scavenge收集器的目标则是达到一个可控制的吞吐量。吞吐量= 程序运行时间/(程序运行时间 + 垃圾收集时间),虚拟机总共运行了100分钟。其中垃圾收集花掉1分钟,那吞吐量就是99%。
Serial Old(串行GC)收集器
Serial Old是Serial收集器的老年代版本,它同样使用一个单线程执行收集,使用“标记-整理”算法。主要使用在Client模式下的虚拟机。
Parallel Old(并行GC)收集器
Parallel Old是Parallel Scavenge收集器的老年代版本,使用多线程和“标记-整理”算法。

7、HotSpot JVM支持哪些垃圾收集器

按线程
单线程:Serial、SerialOld
多线程:ParNew、Parallel Scavenge、Parallel Old、CMS、G1

按适用代
新生代: Serial、ParNew、Parallel Scavenge
老年代: SerialOld、CMS 、Parallel Old
G1可以在新生代和老年代使用

常见的组合
ParNew+CMS
Parallel Scavenge+Parallel Old

与cms垃圾收集器相关的知识