首页 > 其他分享 >【JVM】CMS 收集器的垃圾收集过程

【JVM】CMS 收集器的垃圾收集过程

时间:2024-06-17 12:58:38浏览次数:33  
标签:标记 收集器 应用程序 并发 XX JVM CMS

CMS(Concurrent Mark-Sweep)收集器是Java虚拟机(JVM)中的一种垃圾收集器,它主要面向老年代(Old Generation)的垃圾回收。CMS收集器的目标是最小化垃圾收集的停顿时间,从而提高应用程序的响应性。CMS垃圾收集过程主要分为以下几个阶段:

  1. 初始标记(Initial Marking)

    • 这一阶段标记所有直接可达的对象。由于只是标记GC Roots及其直接关联的对象,所以这个阶段通常很短暂,但会导致短暂停顿(Stop-the-World,STW)。
  2. 并发标记(Concurrent Marking)

    • 在这一阶段,GC线程和应用程序线程是并发执行的。CMS收集器会遍历堆中的对象图,从GC Roots开始标记所有可达的对象。这个阶段是时间最长的一个阶段,因为标记过程是与应用程序并发进行的。
  3. 重新标记(Remarking)

    • 这一阶段修正并发标记阶段中因应用程序运行而导致的标记变化。CMS收集器再次暂停所有应用线程,重新标记在并发标记阶段新产生的可达对象。这一阶段比并发标记短,但也会引起停顿。
  4. 并发清除(Concurrent Sweeping)

    • 在这一阶段,CMS收集器并发地清理未被标记的对象,从而回收内存。这个阶段也是与应用程序线程并发进行的,不会导致应用程序停顿。

优缺点

  • 优点

    • 低停顿时间:由于大部分工作是并发进行的,因此可以减少应用程序的停顿时间,适用于对响应时间敏感的应用。
  • 缺点

    • CPU资源消耗大:并发标记和清除阶段会与应用程序竞争CPU资源,可能会影响应用程序的性能。
    • 浮动垃圾:由于并发特性,在清除阶段可能会有一些垃圾在标记之后产生,这些垃圾无法被立即清除,只能等到下一次GC周期。
    • 内存碎片:CMS是基于标记-清除算法,不会进行内存压缩,这可能导致内存碎片问题,从而导致分配大对象时出现问题。

Java代码示例

以下是一个简单的Java程序,用于演示如何配置JVM以使用CMS收集器:

public class CMSExample {
    public static void main(String[] args) {
        // 启动多个线程,模拟应用程序的负载
        for (int i = 0; i < 10; i++) {
            new Thread(new LoadTask()).start();
        }
    }
}

class LoadTask implements Runnable {
    @Override
    public void run() {
        while (true) {
            // 模拟分配大量内存
            byte[] array = new byte[1024 * 1024];
            try {
                // 模拟一些工作负载
                Thread.sleep(100);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
}

要使用CMS收集器运行上述程序,可以在启动JVM时添加以下参数:

-XX:+UseConcMarkSweepGC

示例:

java -XX:+UseConcMarkSweepGC CMSExample

CMS收集器的JVM参数

以下是一些常见的CMS收集器相关的JVM参数:

  • -XX:+UseConcMarkSweepGC:启用CMS收集器。
  • -XX:CMSInitiatingOccupancyFraction=<N>:在老年代使用率达到N%时启动CMS垃圾收集。
  • -XX:+UseCMSInitiatingOccupancyOnly:只在老年代使用率达到设定值时启动CMS。
  • -XX:+ScavengeBeforeFullGC:在进行Full GC之前先进行一次Minor GC。
  • -XX:+CMSParallelRemarkEnabled:在重新标记阶段启用并行标记。

通过合理配置这些参数,可以在一定程度上优化CMS收集器的性能,使其更好地适应特定应用的需求。

标签:标记,收集器,应用程序,并发,XX,JVM,CMS
From: https://blog.csdn.net/hui_zai_/article/details/139710069

相关文章

  • 首途第三十三套清新简约卡片风格蓝紫渐变色短视频模板 | 苹果CMSV10主题
    下载地址:首途第三十三套清新简约卡片风格蓝紫渐变色短视频模板|苹果CMSV10主题首途第三十三套清新简约卡片风格蓝紫渐变色短视频模板|苹果CMSV10主题我们的简约风格,以纯洁的白色和深邃的紫色为主色调,为您提供了一种清新、时尚的浏览体验。在这个简洁而美丽的界面中,您可以......
  • webshell获取总结(cms获取方法、非cms获取方法、中间件拿Webshell方法)
    目录前期准备:1、cookices靶场网站搭建: 2、dedecms靶场环境搭建:获取Webshell方法总结:一、CMS获取Webshell方法 二、非CMS获取Webshell方法1、数据库备份获取Webshell例如:2、抓包上传获取Webshell3、Sql命令获取Webshell例如:4、模板修改获取Webshell例如:5、插入......
  • JVM-垃圾回收器-ZGC
    新一代垃圾回收器ZGC的探索与实践-美团技术团队Main-Main-OpenJDKWiki介绍        ZGC(ZGarbageCollector)是一款性能比G1更加优秀的垃圾收集器。ZGC第一次出现是在 JDK11中以实验性的特性引入,这也是JDK11中最大的亮点。在JDK15中ZGC不再是实......
  • JVM 调优和深入了解
    调优的原则1、大多数的java应用不需要GC调优2、大部分需要GC调优的的,不是参数问题,是代码问题3、在实际使用中,分析GC情况优化代码比优化GC参数要多得多;4、GC调优是最后的手目的GC的时间够小GC的次数够少发生FullGC的周期足够的长,时间合理,最好是不发生......
  • JVM之编写高效优雅 Java 程序
    面向对象01、构造器参数太多怎么办?如果参数很多,会导致构造方法非常多,拓展性差,代码难编写,且难以看懂。用JavaBeans模式,get和set一行构造编程多行代码实现,需要使用额外机制确保一致性和线程安全。用builder模式,1、5个或者5个以上的成员变量2、参数不多,但是在未来,......
  • JVM类加载机制
    类加载机制概述类从被加载到虚拟机内存中开始,到卸载出内存为止,它的整个生命周期包括:加载(Loading)、验证(Verification)、准备(Preparation)、解析(Resolution)、初始化(Initialization)、使用(Using)和卸载(Unloading)7个阶段。其中验证、准备、解析3个部分统称为连接(Link)。初始化的单例......
  • jvm调优工具和调优策略
    JDK为我们提供的jvm工具命令行工具jps、jstat、jinfo、jmap、jhat、jstack可视化工具JMX、Jconsole、visualvm生产服务器推荐开启-XX:-HeapDumpOnOutOfMemoryError默认关闭,建议开启,在java.lang.OutOfMemoryError异常出现时,输出一个dump.core文件,记录当时的堆内存快......
  • JVM垃圾回收算法和垃圾回收器
    垃圾回收算法复制算法(Copying)将可用内存按容量划分为大小相等的两块,每次只使用其中的一块。当这一块的内存用完了,就将还存活着的对象复制到另外一块上面,然后再把已使用过的内存空间一次清理掉。这样使得每次都是对整个半区进行内存回收,内存分配时也就不用考虑内存碎片等复杂情......
  • JVM中的对象
    虚拟机中的对象对象的分配虚拟机遇到一条new指令时:根据new的参数是否能在常量池中定位到一个类的符号引用,如果没有,说明还未定义该类,抛出ClassNotFoundException1)检查加载先执行相应的类加载过程。如果没有,则进行类加载2)分配内存根据方法区的信息确定为该类分配的内存空......
  • JVM垃圾回收策略机制和算法
    判断对象的存活引用计数法给对象添加一个引用计数器,当对象增加一个引用时计数器加1,引用失效时计数器减1。引用计数为0的对象可被回收。(Python在用,但主流虚拟机没有使用)优点:快,方便,实现简单。缺陷:对象相互引用时(A.instance=B同时B.instance=A),很难判断对象是否该回收。......