`
kavy
  • 浏览: 888023 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

了解CMS(Concurrent Mark-Sweep)垃圾回收器

 
阅读更多

1.总体介绍:

CMS(Concurrent Mark-Sweep)是以牺牲吞吐量为代价来获得最短回收停顿时间的垃圾回收器。对于要求服务器响应速度的应用上,这种垃圾回收器非常适合。在启动JVM参数加上-XX:+UseConcMarkSweepGC ,这个参数表示对于老年代的回收采用CMS。CMS采用的基础算法是:标记—清除。

2.CMS过程:

  • 初始标记(STW initial mark)
  • 并发标记(Concurrent marking)
  • 并发预清理(Concurrent precleaning)
  • 重新标记(STW remark)
  • 并发清理(Concurrent sweeping)
  • 并发重置(Concurrent reset)

初始标记 :在这个阶段,需要虚拟机停顿正在执行的任务,官方的叫法STW(Stop The Word)。这个过程从垃圾回收的"根对象"开始,只扫描到能够和"根对象"直接关联的对象,并作标记。所以这个过程虽然暂停了整个JVM,但是很快就完成了。

并发标记 :这个阶段紧随初始标记阶段,在初始标记的基础上继续向下追溯标记。并发标记阶段,应用程序的线程和并发标记的线程并发执行,所以用户不会感受到停顿。

并发预清理 :并发预清理阶段仍然是并发的。在这个阶段,虚拟机查找在执行并发标记阶段新进入老年代的对象(可能会有一些对象从新生代晋升到老年代, 或者有一些对象被分配到老年代)。通过重新扫描,减少下一个阶段"重新标记"的工作,因为下一个阶段会Stop The World。

重新标记 :这个阶段会暂停虚拟机,收集器线程扫描在CMS堆中剩余的对象。扫描从"跟对象"开始向下追溯,并处理对象关联。

并发清理 :清理垃圾对象,这个阶段收集器线程和应用程序线程并发执行。

并发重置 :这个阶段,重置CMS收集器的数据结构,等待下一次垃圾回收。

 

CSM执行过程: 

3.CMS缺点

  • CMS回收器采用的基础算法是Mark-Sweep。所有CMS不会整理、压缩堆空间。这样就会有一个问题:经过CMS收集的堆会产生空间碎片。 CMS不对堆空间整理压缩节约了垃圾回收的停顿时间,但也带来的堆空间的浪费。为了解决堆空间浪费问题,CMS回收器不再采用简单的指针指向一块可用堆空 间来为下次对象分配使用。而是把一些未分配的空间汇总成一个列表,当JVM分配对象空间的时候,会搜索这个列表找到足够大的空间来hold住这个对象。
  • 需要更多的CPU资源。从上面的图可以看到,为了让应用程序不停顿,CMS线程和应用程序线程并发执行,这样就需要有更多的CPU,单纯靠线程切 换是不靠谱的。并且,重新标记阶段,为空保证STW快速完成,也要用到更多的甚至所有的CPU资源。当然,多核多CPU也是未来的趋势!
  • CMS的另一个缺点是它需要更大的堆空间。因为CMS标记阶段应用程序的线程还是在执行的,那么就会有堆空间继续分配的情况,为了保证在CMS回 收完堆之前还有空间分配给正在运行的应用程序,必须预留一部分空间。也就是说,CMS不会在老年代满的时候才开始收集。相反,它会尝试更早的开始收集,已 避免上面提到的情况:在回收完成之前,堆没有足够空间分配!默认当老年代使用68%的时候,CMS就开始行动了。 – XX:CMSInitiatingOccupancyFraction =n 来设置这个阀值。

总得来说,CMS回收器减少了回收的停顿时间,但是降低了堆空间的利用率。

 

 

转自:http://www.iteye.com/topic/1119491

4.啥时候用CMS

如果你的应用程序对停顿比较敏感,并且在应用程序运行的时候可以提供更大的内存和更多的CPU(也就是硬件牛逼),那么使用CMS来收集会给你带来好处。还有,如果在JVM中,有相对较多存活时间较长的对象(老年代比较大)会更适合使用CMS。

 

 

分享到:
评论

相关推荐

    了解CMS(ConcurrentMarkSweep)垃圾回

    【CMS(Concurrent Mark Sweep)垃圾回收器】是Java虚拟机(JVM)中的一种垃圾收集器,专门针对老年代的内存管理。CMS回收器的主要目标是减少垃圾收集时的应用程序暂停时间,以提高用户体验。它引入了并发模式,允许...

    细述 Java垃圾回收机制→How Java Garbage Collection Works- - Android 1

    3. Concurrent Mark-and-Sweep (CMS) Garbage Collector:并发标记清除垃圾回收器 4. G1 Garbage Collector:G1垃圾回收器 Java中的引用类型 ---------------- Java中有四种不同的引用类型: 1. Strong Reference...

    JVM垃圾回收器工作原理及使用实例介绍Java开发Java

    - CMS(Concurrent Mark Sweep):并发标记清除,减少停顿时间。 - G1(Garbage-First):新一代垃圾回收器,目标区域划分,优先回收高垃圾率区域。 - ZGC(Z Garbage Collector)和Shenandoah:低暂停时间,适用...

    JVM GC问题和垃圾回收器讲解.pdf

    1. CMS(Concurrent Mark Sweep)垃圾回收器: CMS是一款并发的垃圾收集器,它在大部分阶段可以与应用程序线程并发执行,减少了STW(Stop The World)的时间。CMS主要分为初始标记、并发标记、重新标记和并发清除四...

    高吞吐低延迟Java应用的垃圾回收优化.docx

    ### 并发标记清除(Concurrent Mark Sweep, CMS) CMS 垃圾回收器是 Java 应用的默认垃圾回收器之一。CMS 垃圾回收器可以提供低延迟的垃圾回收,但它需要占用大量的 CPU 资源。 ### G1 垃圾回收器 G1 垃圾回收器...

    垃圾回收器分类1

    1. CMS(Concurrent Mark Sweep)回收器:采用标记清除算法,它的特点是并发标记阶段和应用程序线程并发执行,而其他阶段仍然会暂停应用。CMS注重系统的吞吐量,但可能导致内存碎片。 2. G1(Garbage-First)回收器...

    从ES的JVM配置起步思考JVM常见参数优化

    在过去,CMS (Concurrent Mark-Sweep) 垃圾回收器在Java 8中是一种常见选择,因为它在某些场景下能够提供较好的性能。 然而,随着Java版本的不断更新,一些旧的特性和组件被淘汰或替代,比如CMS。Java 14中正式废弃...

    JVM中[垃圾回收器]的所有内容-pdf

    4. **CMS回收器**(Concurrent Mark Sweep):以低延迟为目标,尽量减少应用程序的暂停时间,通过并发地执行大部分垃圾回收任务。然而,在CMS的最终压缩阶段,仍然需要STW。 5. **G1回收器**(Garbage-First):...

    golang 50k 高阶面试题

    而提供的部分内容,则详细介绍了CMS(Concurrent Mark-Sweep)垃圾回收器的面试常见问题,包括其工作原理、特点和面试官可能探询的方向。 在Java虚拟机(JVM)中,CMS垃圾回收器是一种以获取最短回收停顿时间为目标...

    降低Java垃圾回收开销的5条建议

    保持GC低开销的窍门有哪些?  随着一再拖延而即将发布的 Java9,G1(“Garbage First”)垃圾回收器将被成为 HotSpot 虚拟机默认的垃圾回收器。...CMS(“Concurrent Mark-Sweep”)收集器与 parallel GC 相比,它将回收过

    java垃圾回收器代码举例

    - **CMS(Concurrent Mark Sweep)Collector**:并发标记清除收集器,尽量减少停顿时间,适合响应时间敏感的应用。 - **G1(Garbage-First)Collector**:新一代的垃圾回收器,目标是达到可预测的暂停时间。 4. *...

    JAVA虚拟机精讲

    字节码的编译原理、字节码的内部组成结构、通过源码的方式剖析HotSpot VM 的启动过程和初始化过程、Java 虚拟机的运行时内存、垃圾收集算法、垃圾收集器(重点讲解了Serial 收集器、ParNew 收集器、Parallel 收集器...

    Oracle-HotSpot Virtual Machine Garbage Collection.pdf

    Concurrent Mark-and-Sweep (CMS) GC 是一种低 pauses 的垃圾回收算法,它可以在应用程序执行过程中进行垃圾回收操作。这种算法可以减少垃圾回收对应用程序的影响,但可能会增加垃圾回收的开销。 G1 GC 是一种...

    cms-java-源码

    【CMS(Concurrent Mark Sweep)】是Java垃圾收集器的一种,它是HotSpot虚拟机中用于老年代内存管理的并发标记清除算法。这个源码包"cms-java-源码.zip"显然是针对CMS垃圾收集器的Java实现进行的开源分享,旨在帮助...

    Java虚拟机精讲.高翔龙.带书签完整版.pdf

    字节码的编译原理、字节码的内部组成结构、通过源码的方式剖析HotSpot VM 的启动过程和初始化过程、Java 虚拟机的运行时内存、垃圾收集算法、垃圾收集器(重点讲解了Serial 收集器、ParNew 收集器、Parallel 收集器...

    JAVA虚拟机精讲 pdf

    字节码的编译原理、字节码的内部组成结构、通过源码的方式剖析HotSpot VM 的启动过程和初始化过程、Java 虚拟机的运行时内存、垃圾收集算法、垃圾收集器(重点讲解了Serial 收集器、ParNew 收集器、Parallel 收集器...

    JDK16-hotspot-virtual-machine-garbage-collection-tuning-guide

    HotSpot虚拟机提供了多种垃圾回收算法,包括Serial垃圾回收器、Parallel垃圾回收器、Concurrent Mark-and-Sweep(CMS)垃圾回收器和G1垃圾回收器等。 垃圾回收器的配置和调整 垃圾回收器的配置和调整是HotSpot...

    Java理解CMS收集器.pdf

    CMS(Concurrent Mark Sweep)收集器是Java虚拟机中的一种垃圾收集器,主要针对老年代的内存回收,其特点是并发和低停顿。CMS收集器的主要目标是在尽可能短的时间内完成垃圾收集,减少应用程序的暂停时间,提高用户...

    Java 垃圾回收小结(一)

    - CMS(Concurrent Mark Sweep)GC:并发标记清除,尽量减少应用程序暂停时间,适合响应时间敏感的应用。 - G1(Garbage-First)GC:新一代的垃圾回收器,目标是低暂停时间和可预测的内存使用。 3. 垃圾回收算法...

    02垃圾回收器1

    CMS(Concurrent Mark Sweep)收集器是一种老年代的垃圾回收器,它以尽量减少应用程序暂停时间为优化目标。CMS通过并发地执行大部分垃圾收集阶段来实现这一目标,只有在“初始标记”和“最终标记”阶段会暂停应用。...

Global site tag (gtag.js) - Google Analytics