`
youyu4
  • 浏览: 440286 次
社区版块
存档分类
最新评论

JVM之CMS垃圾回收器

 
阅读更多

JVM之CMS垃圾回收器

 

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

 

CMS采用的基础算法是:标记—清除。

 

 

 

CMS垃圾回收的过程

 

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



 

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


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


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


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


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


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

 

 



 

 

 

 

 

 

 

 

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 来设置这个阀值。 

 

  • 为什么要在使用率到70%~80%就要垃圾回收,因为有可能 CMS GC 还在进行,内存就不够了,这样会切换到 Serial Old GC,这个垃圾回收速度就非常快,因为这些原因,CMS也适合内存大些的JVM,最起码>=3G,太小的话会频繁触发CMS GC,还会因为内存碎片太多而空间不够用。

 

 

总结

 

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

 

 

 

什么时候适合使用CMS

 

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

 

 

 

使用CMS垃圾回收的关键

 

  • 老年代有足够的空间
  • 启动CMS垃圾回收周期开始的时机——快到回收对象的速度比转移对象的速度块;这个可以设置老年代占用比例(– XX:CMSInitiatingOccupancyFraction =n),当去到这个比例就CMS回收

 

 

CMS垃圾回收器优化

 

1. 压缩内存碎片:设置下面两个参数

 

-XX:+UseCMSCompactAtFullCollection  

设置在垃圾收集器后是否需要一次内存碎片整理过程,仅在CMS收集器时有效

-XX:+CMSFullGCBeforeCompaction

设置CMS收集器在进行若干次垃圾收集后再进行一次内存碎片整理过程

 

通常两个参数是一起使用,并且在CMS垃圾回收器使用

 

 

2. 防止CMS GC时内存不够,进入Serial Old GC

 

  • 压缩内存碎片,就是上面说的方法
  • 增加老年代至少20%~30%,以延迟垃圾回收
  • 减少对象从年轻代复制到老年代(加大年轻代、加多Survivor区,增加对象的岁数)

 

3. 优化CMS响应时间

 

从stop the world的步骤入手:分别是下面两个步骤:

  • 初始标价,比较快速,不需要优化
  • 重新标记:设置某个配置,在Full GC 之前做一次 Minor GC,减少对象

 

4. 优化CMS吞吐量

 

这个优化的目的,就是减少垃圾回收器占用CPU时间,把CPU留给应用计算

 

  • 增加年轻代大小,j减少Minor GC的频率,从而减少Minor GC占用时间
  • 增加老年代大小,减少Full GC的频率,减少碎片
  • 优化堆大小,减少从年轻代复制到老年代的对象
  • 优化CMS周期的启动

 

 

 

 

  • 大小: 21.8 KB
  • 大小: 49.9 KB
  • 大小: 53.5 KB
  • 大小: 50.8 KB
  • 大小: 50.3 KB
  • 大小: 51.8 KB
  • 大小: 42.2 KB
分享到:
评论

相关推荐

    JVM面试资料:JVM结构、JVM调优、四大垃圾回收算法、七大垃圾回收器

    JVM面试资料。 JVM结构:类加载器,执行引擎,本地方法接口,本地内存结构;...七大垃圾回收器:Serial、Serial Old、ParNew、CMS、Parallel、Parallel Old、G1 JVM调优:命令行指令,设置堆内存大小的参数

    JVM垃圾回收机制与GC性能调优

    Java虚拟机(JVM)的垃圾回收(GC)机制是Java程序高效运行的关键部分,它自动管理内存,释放不再使用的对象以避免内存泄漏。本文主要探讨JVM堆内存的结构和GC的工作原理,以及如何进行性能调优。 JVM堆是Java应用...

    JVM入门实战/arthas实战/垃圾回收算法/垃圾回收器/jvm内存模型分析

    第五节:垃圾回收器 1.1Serial/Serial Old收集器 1.2 ParNew收集器 1.3Parallel Scavenge收集器 1.4Parallel Old收集器 1.5CMS(Current Mark Sweep)收集器 1.6G1收集器 第六节:JVM参数调优 1.1 JVM重要参数介绍...

    jvm内存模型以及垃圾回收机制.pptx

    Java虚拟机(JVM)内存模型和垃圾回收机制是Java开发中至关重要的概念。本文将深入探讨这两个主题,帮助理解JVM如何管理...开发者应根据实际需求选择合适的垃圾回收器,并关注内存分配策略,以实现高效稳定的程序运行。

    JVM的垃圾回收机制详解和调优

    Java虚拟机(JVM)是Java程序运行的基础,它的核心组成部分之一就是垃圾回收(Garbage Collection,简称GC)。GC是JVM自动管理内存的主要方式,它负责识别并清理不再使用的对象,以避免内存泄漏和资源浪费。理解并...

    JVM之垃圾回收器

    **JVM之垃圾回收器** Java虚拟机(JVM)是Java编程语言的核心组成部分,它负责执行字节码并管理程序运行时的内存。在JVM的内存模型中,垃圾回收(Garbage Collection, GC)是一项重要的功能,它自动识别并清理不再...

    JVM之基本的垃圾回收算法汇总

    并发收集则是在应用线程运行的同时进行GC,尽可能减少对应用性能的影响,如CMS(Concurrent Mark Sweep)和G1(Garbage-First)垃圾回收器。 7. G1垃圾回收器 G1是Oracle JDK 1.6引入的一种新的垃圾回收器,它结合...

    JVM结构+垃圾回收器+锁总结.xmind

    JVM结构+垃圾回收器+锁总结

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

    Java虚拟机(JVM)中的垃圾回收器(Garbage Collector, GC)是Java程序自动管理内存的关键组件。垃圾回收器负责识别不再使用的对象并回收它们所占用的内存,以防止内存泄漏并确保程序的稳定运行。理解不同类型的垃圾...

    JVM历史发展和内存回收笔记

    6. **Java 7与G1 GC**:2011年,Java 7引入了G1(Garbage First)垃圾回收器,它是一种并行、并发且具有低延迟特性的垃圾回收器,适用于大型应用。 7. **Java 8与元空间**:2014年,Java 8中,永久代被元空间...

    JVM垃圾回收器和内存分配策略.zip

    Java虚拟机(JVM)是Java程序运行的基础,它的核心组成部分之一就是垃圾回收器(Garbage Collector, GC),以及内存分配策略。理解这些概念对于优化Java应用性能至关重要。本篇文章将深入探讨JVM的垃圾回收机制以及...

    jvm垃圾回收机制总结

    2. ParNew GC:Serial GC的多线程版本,常与CMS(Concurrent Mark Sweep)垃圾回收器配合使用,主要负责新生代的垃圾回收。 3. Parallel GC:与ParNew类似,但适用于老年代,同样采用多线程。 4. CMS GC:并发标记...

    垃圾回收垃圾回收垃圾回收

    当一个对象不再有任何引用指向它时,这个对象就会被认为是“垃圾”,垃圾回收器会适时地将其占用的内存空间释放出来,供后续分配新对象使用。 JVM中的垃圾回收主要分为以下几个阶段: 1. **标记阶段**:此阶段垃圾...

    JVM内存管理和垃圾回收

    Java虚拟机(JVM)是Java程序运行的基础,它的内存管理与垃圾回收机制对于程序的性能至关重要。在Java中,内存分为堆内存、栈内存、方法区、程序计数器和本地方法栈五个主要区域。下面我们将深入探讨这些区域以及...

    jvm内存模型以及垃圾回收机制.rar

    JVM的垃圾回收器有多种,如串行GC(Serial GC)、并行GC(Parallel GC)、并发标记扫描GC(CMS, Concurrent Mark Sweep)和G1垃圾收集器等。选择合适的垃圾回收器取决于应用的需求,例如,对于响应时间敏感的应用,...

    jvm内存基本结构及垃圾回收

    理解JVM内存结构和垃圾回收机制对于Java开发者至关重要,它可以帮助我们更好地优化程序性能,避免内存溢出等问题。通过调整JVM参数,如堆大小、新生代与老年代的比例、垃圾收集器的选择等,我们可以根据应用的需求...

    JVM内存管理和JVM垃圾回收

    JVM的垃圾回收策略通常是组合使用的,例如,并行GC与CMS配合,以实现高效且低延迟的垃圾回收。 理解JVM内存管理和垃圾回收机制对于优化Java应用的性能至关重要。开发者可以根据应用的需求和特点,通过调整JVM参数来...

    CMS垃圾收集器1

    CMS垃圾收集器是一种Java虚拟机(JVM)的老年代垃圾收集器,它的主要目标是减少垃圾收集时的停顿时间,以提供更优秀的响应速度,适合于需要低延迟且CPU资源充足的服务器应用。CMS基于“标记-清除”算法,这意味着它...

Global site tag (gtag.js) - Google Analytics