CMS那点事

大家好,今天我们来深入探讨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.mzph.cn/bicheng/60271.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

中仕公考:大三大四考公备考时间线

大三大四想要考公务员的可以借鉴以下时间线: 大三下学期: 基础看课阶段,刚开始先打好基础很重要,根据课程和教材理解知识点,按照模块学习,对考试科目的题型有深入的认识和掌握。 大四初: 强…

Android Studio 将项目打包成apk文件

第一步:选择Build -> Generate Signed APK 会出现: 我们选择 Create new… 然后选择你要存放密钥的地方 点击ok之后,则选择好了文件,并生成了jks文件了。 点击ok之后, 会出现: 选择release&#xf…

FFmpeg存放压缩后的音视频数据的结构体:AVPacket简介,结构体,函数

如下图的解码流程,AVPacket中的位置 FFmpeg源码中通过AVPacket存储压缩后的音视频数据。它通常由解复用器(demuxers)输出,然后作为输入传递给解码器。 或者从编码器作为输出接收,然后传递给多路复用器(mux…

纺织品缺陷检测

项目源码获取方式见文章末尾! 600多个深度学习项目资料,快来加入社群一起学习吧。 《------往期经典推荐------》 项目名称 1.【基于CNN-RNN的影像报告生成】 2.【卫星图像道路检测DeepLabV3Plus模型】 3.【GAN模型实现二次元头像生成】 4.【CNN模型实现…

SSM房屋销售管理系统-计算机毕业设计源码49529

摘 要 随着国民生活水平的提高,人们日益重视休闲旅游,而互联网的普及也为房屋销售管理带来了新的机遇。将房屋租赁产业与互联网相结合,利用 SSM 框架建设房屋销售管理系统,实现房屋销售管理的网络化,对提高国民经济发展…

【PLC一体机】触摸屏上一直显示ERR警示灯的原因和解决方法

博主之前买了一个PLC一体机,在触摸屏上有ERR、RUN和SYS三个显示灯(如下图) 其中触摸屏工作时,RUN显示灯会显示为绿色,证明触摸屏正常工作。 SYS是触摸屏上刷写PLC程序和触摸屏程序时,会显示为橙色&#xf…

(十四)JavaWeb后端开发——MyBatis

目录 1.MyBatis概述 2.MyBatis简单入门 3.JDBC(了解即可) 4.数据库连接池​ 5.lombok 6.MyBatis基本操作 7.XML映射文件 8.动态SQL 8.1 if标签 8.2 foreach标签 8.3 sql/include标签​ 1.MyBatis概述 MyBatis是一款优秀的持久层&#xff08…

Elasticsearch可视化工具Elasticvue插件用法

目录 1.打开浏览器扩展程序(示例Edge浏览器) ​2.搜索elasticvue并安装 3.打开elasticvue ​4.连接Es 5.有些浏览器无法下载安装扩展,例如谷歌。可以打包扩展给别的浏览器使用。 5.1打开浏览器扩展,打开开发人员模式,记住扩展程序id 5…

数据结构之排序补充

1. 非比较排序 上一篇文章我们罗列了数据结构中排序的八种方法。这八种方法都是需要比较才能实现的,那怎么样才可以通过非比较的方法来实现数组的排序呢?这里就提供一种非比较排序的方法。 具体的操作思路如下: 1. 先统计待比较数组arr中重…

1.62亿元!812个项目立项!上海市2024年度“科技创新行动计划”自然科学基金项目立项

本期精选SCI&EI ●IEEE 1区TOP 计算机类(含CCF); ●EI快刊:最快1周录用! 知网(CNKI)、谷歌学术期刊 ●7天录用-检索(100%录用),1周上线; 免费稿件评估 免费匹配期…

危!这些高危端口再不知道问题就大了

号主:老杨丨11年资深网络工程师,更多网工提升干货,请关注公众号:网络工程师俱乐部 下午好,我的网工朋友。 端口作为网络通信的基本单元,用于标识网络服务和应用程序。 但某些端口由于其开放性和易受攻击的…

Excel中截取中文地址转换为省、市、区

使用方法/步骤 首先我们在网页打上方方格子,进入官网,下载方方格子。 解压后进行安装,打开OFFIE中的EXCEL,可以发现新新添加一个DIY工具箱,其中的提取地址功能可以将字符串地址解析为省、市、区 如下图所示

引入 axios,根据 api 文档生成调用接口

起步 | Axios Docs 安装 axios npm install axios 生成 api 调用接口【可选】 https://github.com/ferdikoomen/openapi-typescript-codegen 安装 npm install openapi-typescript-codegen --save-dev 然后执行生成代码 # http://localhost:8805/api/user/v3/api-docs&a…

2款使用.NET开发的数据库系统

今天大姚给大家分享2款使用.NET开发且开源的数据库系统。 Garnet Garnet是一款由微软研究院基于.NET开源的高性能、跨平台的分布式缓存存储数据库,该项目提供强大的性能(吞吐量和延迟)、可扩展性、存储、恢复、集群分片、密钥迁移和复制功能…

ARM-8 定位发布版本 pstree 程序的 main 地址

逆向时如何找到main,如下: 1.readelf -h pstree ELF Header: Magic: 7f 45 4c 46 02 01 01 00 00 00 00 00 00 00 00 00 Class: ELF64 Data: 2s complement, little endian Versi…

13.UE5流星火雨,引导施法技能制作

2-15 流星火雨,引导施法技能制作、随机数_哔哩哔哩_bilibili 目录 1.为流星火雨添加按键映射 2.创建流星火雨的动画蒙太奇 3.实现播放动画蒙太奇的逻辑 ​编辑 4.定义发射一波流星火雨的发射物 5.使用动画通知释放流星火雨 1.为流星火雨添加按键映射 创建名为流…

Web大型网站的性能测试要求和工具方法

Web大型网站的性能测试要求和工具方法涉及多个层面的考量,旨在确保网站在高并发访问、大数据量处理、复杂交互场景下仍能保持良好的用户体验和系统稳定性。以下是针对大型网站性能测试的主要要求和相应的工具与方法: 性能测试要求 1. 高并发处理能力&…

贪心算法day3(最长递增序列问题)

目录 1.最长递增三元子序列 2.最长连续递增序列 1.最长递增三元子序列 题目链接:. - 力扣(LeetCode) 思路:我们只需要设置两个数进行比较就好。设a为nums[0],b 为一个无穷大的数,只要有比a小的数字就赋值…

在CentOS7传统部署wordpress

1 环境准备 所需环境说明CentOS7.9ip地址:10.0.0.7,可以上网PHP72系列软件下面会介绍MySQL数据库暴露端口3306,用户wordpress,库wordpressnginx版本任意wordpres v6.5.2代码下载地址:https://cn.wordpress.org/wordpr…

文献阅读 | Nature Methods:使用 STAMP 对空间转录组进行可解释的空间感知降维

文献介绍 文献题目: 使用 STAMP 对空间转录组进行可解释的空间感知降维 研究团队: 陈金妙(新加坡科学技术研究局) 发表时间: 2024-10-15 发表期刊: Nature Methods 影响因子: 36.1&#xff0…