Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >CMS GC:CMS 废弃了,该怎么办呢?

CMS GC:CMS 废弃了,该怎么办呢?

作者头像
涤生
发布于 2019-10-12 08:10:58
发布于 2019-10-12 08:10:58
3.1K00
代码可运行
举报
文章被收录于专栏:涤生的博客涤生的博客
运行总次数:0
代码可运行

优质文章,及时送达

在 JDK 9 中 CMS GC 被废弃后,现有应用程序的最佳处理方法是什么?

流行的 CMS( Concurrent Mark Sweep) GC 算法在 JDK 9 中被废弃了。根据 JEP-291 中的说明,为了减轻 GC 代码的维护负担以及加速新功能开发,决定在 JDK9 中废弃CMS GC。

因此,从 Java 9 开始,如果您使用 -XX:+UseConcMarkSweepGC(激活 CMS GC 算法的参数)参数启动应用程序,则会在下面显示警告消息:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Java HotSpot(TM) 64-Bit Server VM warning: Option UseConcMarkSweepGC was deprecated in version 9.0 and will likely be removed in a future release.

为什么 CMS GC 会被废弃?

大家都知道轻装上阵,才能加速前行。CMS GC 也是如此。CMS 是一种高度可配置的复杂算法,因此给 JDK 中的 GC代码库带来了很多复杂性。只有 JDK 开发团队简化了 GC 代码库,他们才能在 GC 领域加速和创新。下表总结了可以传递给每个 GC 算法的 JVM 参数的数量:

GC 算法

JVM 参数(约数)

Common to all

50

Parallel

6

CMS

72

G1

26

ZGC

8

JVM 大约有 50 个通用的适合所有所有 GC 算法的参数,除了这 50 个参数之外,仅对于 CMS,您还可以传递 72 个额外的参数。如上表所示,此参数比其他任何 GC 算法都要多得多。因此,可想而知,JDK 团队支持所有这些参数所需的编码复杂性。

如果使用了 CMS,后面该怎么办呢?

就目前来看,其实无非就三种选项:

  1. 切换到 G1 GC 算法
  2. 切换到 Z GC 算法(JDK 11、12 中的早期版本)
  3. 继续使用 CMS

接下来,我们来分析下每个选项。

(1)切换到 G1 GC 算法

自 Java 9 以来,G1 GC 已成为默认的 GC 算法。因此,可以考虑将应用程序的 GC 算法移至 G1。它可能会比 CMS GC 算法有更好的性能表现。调参相对较少,因此调整起来容易得多。此外,它还提供了用于从内存中消除重复的字符串的参数选项。如果可以消除重复的字符串,可以减少总体内存占用也是极好的。

(2)切换到 Z GC 算法

Z GC 是一种可扩展的低延迟垃圾回收器。其目标是使 GC 暂停时间小于 10ms。Java 11 和 12 中提供了对 Z GC 算法的早期版本。因此,如果你的应用程序在 Java 11 或 12 上运行,则可以考虑升级到 Z GC 算法。我们对 Z GC 的做了初步实验,都显示了极好的结果。

(3)继续使用CMS

我们发现,对于某些应用程序经过一些参数优化,CMS GC 可以提供 G1 GC 无法提供的出色结果。因此,如果您已经研究过上面两个选项,并且确信只有 CMS GC 算法就是适合你的应用程序,那么可以考虑继续使用 CMS 算法来运行。在 OpenJDK JDK9-dev 邮件列表中,甚至还有继续让 CMS 保持可用状态 的争论。根据我个人的经验,在 Java 1.1 中已废弃的功能和 API 在 Java 12 中仍然还是存在的(即使 20 年之后)。所有已弃用的 API 和功能似乎都可以保留(并且永远不会消失)。因此,继续在使用 CMS GC 也是一种选择。当然,这完全按照你的需要。

结论

请注意,每个应用程序都是唯一且不同的。因此,不要被在互联网上看到的有关 GC 调优(包括本文)的文章所迷惑。当你测试新的 GC 参数配置时,你需要进行彻底的测试,可以看看基准性能特征,然后再做决定。

原文:https://dzone.com/articles/cms-deprecated-next-steps

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-10-11,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 涤生的博客 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
CMS GC已成过去式
CMS,全称“ Concurrent-Mark-Sweep”,是一款并发的、使用标记-清除算法的垃圾回收器,如果老年代采用CMS垃圾回收器,则需要在应用服务Java虚拟机启动参数中配置关键字:-"XX:+UseConcMarkSweepGC"。
Luga Lee
2021/12/09
1.2K0
CMS GC已成过去式
Java虚拟机 G1 GC 调优解析
依据官方 Java 虚拟机的规划,自 Java 9 开始,在实际的生产环境中不再建议使用基于 ConcurrentMarkSweep(CMS)垃圾收集器。根据 JEP-291,已做出此决定以减轻GC 代码库的维护负担并加速新开发。毕竟,Java 9 之后,G1 GC 已成为默认的 GC 算法。(当然,基于不同的环境,Z 垃圾收集器-ZGC 、Shenandoah GC 亦逐渐开始成为主流算法)因此,我们可以根据实际业务场景考虑将我们的应用程序移至该算法。它可能提供比 CMS GC 算法更优的性能特征。由于其参数相对较少,因此调整起来要容易得多。此外,G1 同时也提供了一些选项以从内存中消除重复的字符串,从而可以帮助我们应用减少总体内存占用。
Luga Lee
2021/12/09
1.7K0
Java虚拟机 G1 GC 调优解析
JVM真香系列:图解垃圾回收器
并发收集:指用户线程与垃圾收集线程同时工作(不一定是并行的可能会交替执行)。用户程序在继续运行,而垃圾收集程序运行在另一个CPU上。
田维常
2020/11/19
4080
JVM真香系列:图解垃圾回收器
一张PDF了解JDK9 GC调优秘籍-附PDF下载
今天我们讲讲JDK9中的JVM GC调优参数,JDK9中JVM的参数总共有2142个,其中正式的参数有659个。好像比JDK8中的参数要少一点。
程序那些事
2020/07/08
5010
一张PDF了解JDK9 GC调优秘籍-附PDF下载
你应该知道的Java垃圾收集器 - 串行、并行、CMS、G1
当我们谈论垃圾收集时,绝大多数人都知道这个概念,并在日常编程中使用它。即使如此,有关垃圾收集,我们很多人还是不太明白。关于JVM的一个最大的误解是它有一个垃圾收集器,其实它提供了四个不同的垃圾收集器,每一个都有自己独特的优点和缺点。重要的是,我们编程的时候可以通过JVM选择垃圾回收器类型。我们通过向JVM传递参数进行选择。每种类型在很大程度上有所不同并且可以为我们提供完全不同的应用程序性能。理解每种类型的垃圾回收器并且根据应用程序选择进行正确的选择是非常重要的。 这四种垃圾收集算法的共同点是,它们都是分
ImportSource
2018/04/03
2.4K0
你应该知道的Java垃圾收集器 - 串行、并行、CMS、G1
Java 垃圾收集器详解:CMS, G1, ZGC
Java 虚拟机(JVM)内置的垃圾收集机制是 Java 程序能够自动管理内存的关键。随着 Java 应用程序规模的增长和技术的进步,垃圾收集器的设计也在不断演进,以满足更高性能、更低延迟的需求。本文将详细介绍 CMS、G1 和 ZGC 这三种垃圾收集器,并提供一个详细的对比表格。
井九
2024/10/12
3370
Java 垃圾收集器详解:CMS, G1, ZGC
JVM 垃圾收集器-Java快速进阶教程
在本快速教程中,我们将演示不同JVM 垃圾回收 (GC) 实现的基础知识。然后,我们将学习如何在应用程序中启用特定类型的垃圾回收。
jack.yang
2025/04/05
1160
你不知道的CMS GC
在G1出来之前,CMS绝对是OLTP系统的标配。即使G1出来几年了,生产环境很多的JVM实例还是采用ParNew+CMS的组合。但是即使其得到这么广泛的应用,还是有很多同学对它有很深的误解。本文主要对ParNew+CMS经典组合下,触发的几种垃圾回收方式进行几个概念的纠正。
Java_老男孩
2019/12/03
9800
你不知道的CMS GC
Java 虚拟机之 CMS GC 调优解析
随着 JDK 版本的不断升级,其 GC 策略也随之不停革新,从早期的 1.4 到如今的 11(本文仅讨论在线上环境落地规模较大的版本),其对应的 GC 策略也随之由 Serial、Parallel、CMS 演进至当前的 G1 甚至即将落地的 ZGC 。每一次的调整无不是基于环境的适配性以及业务场景特性,无论如何,只要能够基于特定的操作系统内核、物理内存、JDK 版本以及业务特性,达到收益最大化,采用何种实现策略都不为过。当然,还是建议大家以官方的推荐为准,基于自己的业务场景进行不断优化调整,这样才能保证万无一失,使得我们的业务能够健康发展。
Luga Lee
2021/11/25
8230
Java 虚拟机之 CMS GC 调优解析
这三大特性,让 G1 取代了 CMS!
之前我们聊过 CMS 回收器,但那时候我们说 CMS 回收器已经落伍了,现在应该是用 G1 回收器的时候了。那么 G1 回收器到底有什么魔力,它比 CMS 回收器相比强在哪里呢?今天,就让树哥带大家盘一盘!
陈树义
2022/09/28
1.3K0
这三大特性,让 G1 取代了 CMS!
JVM GC杂谈之理论入门
GC杂谈之理论入门 ---- JVM堆布局介绍 ​ JVM堆被划分成两个不同的区域:新生代 ( Young )、老年代 ( Old )。新生代 ( Young ) 又被划分为三个区域:Eden、From Survivor、To Survivor,其中两个Survivor区的大小一致。 ​ \(堆新生代老年代老年代java堆 = 新生代(Young) + 老年代(Old) = 老年代(Old) + Eden + From Survivor + To Survivor\) ​ 特殊参数说明: JVM参数
SecondWorld
2018/03/14
8410
JVM GC杂谈之理论入门
Java常见的垃圾收集器有哪些?
Serial GC, 它是最古老的垃圾收集器, “Serial”体现在其收集工作是单线程的,并且在进行垃圾收集过程中,会进入臭名昭著的“Stop-The-World”状态。当然,其单线程设计也意味着精简的GC实现,无需维护复杂的数据结构,初始化也简单,所以一直是Client模式下JVM的默认选项。 从年代的角度,通常将其老年代实现单独称作Serial Old,它采用了标记-整理(Mark-Compact)算法,区别于新生代的复制算法。Serial GC的对应JVM参数是:-XX:+UseSerialGC
葆宁
2019/04/18
9950
高吞吐低延迟 Java 应用的 GC 优化
本篇原文作者是 LinkedIn 的 Swapnil Ghike,这篇文章讲述了 LinkedIn 的 Feed 产品的 GC 优化过程,虽然文章写作于 April 8, 2014,但其中的很多内容和知识点非常有参考意义。因此,翻译后献给各位同学。
涤生
2019/04/24
2K0
高吞吐低延迟 Java 应用的 GC 优化
JVM活学活用——GC算法 垃圾收集器
概述 ----  垃圾收集 Garbage Collection 通常被称为“GC”,它诞生于1960年 MIT 的 Lisp 语言,经过半个多世纪,目前已经十分成熟了。 jvm 中,程序计数器、虚拟机栈、本地方法栈都是随线程而生随线程而灭,栈帧随着方法的进入和退出做入栈和出栈操作,实现了自动的内存清理,因此,我们的内存垃圾回收主要集中于 java 堆和方法区中,在程序运行期间,这部分内存的分配和使用都是动态的。 对象存活判断 ----  判断对象是否存活一般有两种方式: 引用计数:每个对象有一个引用计数属
Janti
2018/04/10
6650
JVM活学活用——GC算法 垃圾收集器
弄明白CMS和G1,就靠这一篇了
CMS和G1作为垃圾收集器里的大杀器,是需要好好弄明白的,而且面试中也经常被问到。
猿人谷
2020/06/19
11.8K0
关于 CMS 垃圾回收器,你真的懂了吗?
前段时间有个小伙伴去面试,被问到了 CMS 垃圾回收器的详细内容,没答出来。实际上,CMS 垃圾回收器是回收器历史上很重要的一个节点,其开启了 GC 回收器关注 GC 停顿时间的历史。今天,就让树哥带你一起来学一波吧!
陈树义
2022/10/05
1K0
关于 CMS 垃圾回收器,你真的懂了吗?
深入解析CMS垃圾回收器
前面几篇文章都在介绍GC的工作原理,下面开始大家期待的垃圾回收器章节。一共有三篇:CMS、G1和ZGC。
BookSea
2023/08/29
3260
深入解析CMS垃圾回收器
垃圾回收器分类
有了虚拟机,就一定需要收集垃圾的机制,这就是Garbage Collection,对应的产品我们称为Garbage Collector。
编程之心
2021/07/14
7350
垃圾回收器分类
GC 知识点补充——CMS
之前已经讲过了不少有关 GC 的内容,今天准备将之前没有细讲的部分进行补充,首先要提到的就是垃圾收集器。
健程之道
2019/11/03
7210
搞定这24道JVM面试题,要价30k都有底气~
JVM 的全称是 「Java Virtual Machine」,也就是我们耳熟能详的 Java 虚拟机。它能识别 .class后缀的文件,并且能够解析它的指令,最终调用操作系统上的函数,完成我们想要的操作。
田维常
2020/12/30
4100
相关推荐
CMS GC已成过去式
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验