CMS几种GC模式解读

在G1出来之前,CMS绝对是OLTP系统的标配。即使G1出来几年了,生产环境很多的JVM实例还是采用ParNew+CMS的组合。但是即使其得到这么广泛的应用,还是有很多同学对它有很深的误解。本文主要对ParNew+CMS经典组合下,触发的几种垃圾回收方式进行几个概念的纠正。

Backgroud CMS

可能更多人只知道CMS,而不知道Backgroud CMS。事实上我们说的CMS,即包含了5个阶段的CMS,就是Background CMS,如下图所示:

CMS示意图

说明

  • 图中初始化标记阶段是串行的,这是JDK7的行为。JDK8以后默认是并行的,可以通过参数-XX:+CMSParallelInitialMarkEnabled控制。
  • 由图可知,CMS还有两个阶段是完全STW(Stop The World)的,即初始化标记和最终标记(重新标记)。
  • 其他阶段都是并发的,所以CMS被称为Concurrent Mark&Sweep,但是我认为前面还需要加个Mostly才是最贴切,即CMS是一个Mostly Concurrent Mark and Sweep Garbage Collector,因为它还没办法做到完全
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java虚拟机(JVM)调优主要有以下几种方法: 1. 堆内存调优:JVM的堆内存是用来存储对象的地方,可以通过调整堆内存的大小来提升性能。一般来说,应该根据应用程序的需求和服务器的硬件配置来合理地分配堆内存大小。如果堆内存太小,可能会导致频繁的垃圾回收,降低性能;如果堆内存太大,可能会导致内存浪费。 2. GC调优:GC(垃圾回收)是JVM管理内存的机制。通过调整GC算法和参数,可以优化内存的回收和释放。常见的GC算法有串行GC、并行GCCMS GC、G1 GC等,可以根据应用程序的特点选择合适的GC算法,以获得更好的性能。另外,还可以通过设置GC参数(如-Xms、-Xmx、-XX:NewRatio等)来优化GC过程。 3. 线程调优:JVM中的线程是执行程序的基本单位。通过合理管理和调优线程,可以提高程序的并发性能。例如,可以通过合理地使用线程池、减少线程的创建和销毁、降低线程的阻塞时间等来提升性能。 4. 内存分析工具调优:使用内存分析工具(如VisualVM、Eclipse Memory Analyzer等),可以监测应用程序的内存使用情况,并识别内存泄漏和性能瓶颈。通过分析工具提供的信息,可以定位问题并采取相应的优化措施。 综上所述,JVM调优主要包括堆内存调优、GC调优、线程调优和使用内存分析工具进行优化。根据具体的应用场景和问题,可以结合这些方法来提高Java应用程序的性能和稳定性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值