CMS那点事

embedded/2024/11/14 18:58:24/

大家好,今天我们来深入探讨JVM垃圾回收机制中备受关注的老年代垃圾回收器——CMS(Concurrent Mark Sweep)。

CMS垃圾回收算法:标记-清理

CMS的核心算法是标记-清理。简单来说,它分为两个主要步骤:

  1. 标记: 从GC Roots出发,遍历所有可达对象,标记为存活对象。不可达的对象则被标记为垃圾对象。

  2. 清理: 将标记为垃圾的对象从内存中移除,释放空间。

CMS执行过程:并发与暂停的交织

CMS最大的特点在于它尽可能地与应用程序并发执行,减少垃圾回收对系统性能的影响。整个过程分为四个阶段:

  1. 初始标记(Initial Mark): 会发生Stop The World (STW),短暂暂停所有应用程序线程,快速标记GC Roots直接引用的对象。

  2. 并发标记(Concurrent Mark): 应用程序线程继续运行,CMS线程同时进行GC Roots追踪,标记所有可达对象。

  3. 重新标记(Remark): 会发生Stop The World (STW),再次短暂暂停应用程序线程,标记并发标记阶段新创建或变为垃圾的对象。

  4. 并发清理(Concurrent Sweep): 应用程序线程继续运行,CMS线程清理标记为垃圾的对象。

CMS的优势与应用场景

  • 并发执行: 最大程度减少垃圾回收对应用程序的影响,适用于对响应时间要求较高的应用场景。

  • 低停顿: 除了初始标记和重新标记阶段的短暂暂停,其他阶段与应用程序并发执行,减少了停顿时间。

  • 适用场景: 适用于老年代对象存活时间较长、对响应时间敏感的应用程序,如Web服务器、应用服务器等。

  • 老年代垃圾回收器: CMS的设计目标是减少垃圾回收停顿时间,这对于老年代尤为重要。老年代通常存储生命周期较长的对象,如果采用STW时间较长的垃圾回收算法,会严重影响应用程序的响应性能。

CMS的不足与优化策略

  • 内存碎片:

  • 问题: 标记-清理算法容易产生内存碎片,可能导致分配大对象时空间不足。

    • 解决方案:

    • 开启整理碎片功能:-XX:+UseCMSCompactAtFullCollection参数,在Full GC时进行内存碎片整理(JDK 9后已弃用)。

    • 设置整理频率:-XX:CMSFullGCsBeforeCompaction参数,设置进行多少次Full GC后进行一次碎片整理。

  • 浮动垃圾:

    • 问题: 并发清理阶段产生的垃圾无法及时清理,可能导致并发模式失败(Concurrent Mode Failure)。

    • 解决方案: 调整CMS GC触发时机:通过-XX:CMSInitiatingOccupancyFraction参数,降低CMS GC的触发阈值,提前进行垃圾回收。

  • CPU资源占用:

    • 问题: 并发执行需要占用额外的CPU资源,可能对应用程序性能产生一定影响。

    • 解决方案: 调整CMS GC线程数:通过-XX:ConcGCThreads参数,控制CMS GC线程数,减少对应用程序的影响。

CMS垃圾回收器通过并发执行和低停顿的特点,为Java应用程序提供了更流畅的用户体验。尤其适用于老年代垃圾回收,能有效减少长时间的停顿,提升应用的响应性能。虽然CMS存在内存碎片、浮动垃圾和CPU占用等问题,但可以通过合理的参数调优来缓解这些问题,使其更好地服务于我们的应用程序。


http://www.ppmy.cn/embedded/136819.html

相关文章

外贸行业热门CRM系统大盘点

在全球化的今天,外贸行业面临着激烈的竞争和复杂的市场环境。为了在这个竞争激烈的市场中脱颖而出,企业需要有效的客户关系管理(CRM)系统来帮助他们管理客户信息、优化销售流程和提高客户满意度。本文将盘点外贸行业中一些热门的C…

Redis设计与实现 学习笔记 第十六章 Sentinel

Sentinel(哨岗、哨兵)是Redis的高可用性(high availability)解决方案:由一个或多个Sentinel实例(instance)组成的Sentinel系统可以监视任意多个主服务器,以及这些主服务器属下的从服…

C#强大的应用场景和优势

一、简洁优雅的语法 清晰的代码结构 C# 采用了类似于 C 和 C++ 的语法风格,但更加简洁和易读。它具有明确的代码块结构,通过大括号来界定代码的范围,使得代码的层次结构一目了然。例如,在 C# 中定义一个类和方法非常直观:class MyClass {public void MyMethod(){// 方法体…

Ubuntu 20.04配置ollama并下载安装调用本地大语言模型

Ubuntu 20.04配置ollama并下载安装调用本地大语言模型 ollama 介绍(来自ChatGPT)主要特点 ollama开发环境预配置ollama在ubuntu下的安装直接安装压缩包安装创建开机ollama的脚本启动ollama ollama在ubuntu下的运行 ollama 介绍(来自ChatGPT) Ollama 是一种新的本地语言模型管理…

C++动态库和静态库的特点以及区别

目录 命名规则使用方式发布方式资源占用运行效率更新方式加载方式其他 C的库文件包括动态库和静态库两种,可以说是开发的时候必然会接触的内容,应该都很熟悉了,这篇文章就简单聊一下这两种库的特点以及区别。 命名规则 在Windows系统中动态…

Autosar CP Can State Mangement规范导读

CanSM的主要功能 CAN网络通信模式控制 管理CAN网络的启动、停止和不同通信模式(如全通信、静默通信、无通信)之间的切换。通过状态机实现对CAN网络状态的精确控制,确保网络在不同条件下稳定运行。错误处理与状态报告 根据AUTOSAR基础软件的错误分类方案处理错误,包括开发错…

【vue2.0入门】认识vue工程

目录 引言一、工程目录介绍1. package.json文件2. src\App.vue3. src\components 文件夹4. src\assets 文件夹5. node_modules 文件夹6. 其他 二、安装 vuejs devtools 插件1. 下载插件2. 配置插件3. 使用插件 三、总结 引言 本系列教程旨在帮助一些零基础的玩家快速上手前端开…

MySQL压缩版安装详细图解

1.下载 mysql压缩包版本和msi版的安装方法不一样,下面的是压缩包版本的安装详细图解: 总地址下载地址:MySQL :: Download MySQL Community Server MySQL :: Download MySQL Community Server (Archived Versions) 压缩版下载MySQL :: Dow…