博客
关于我
垃圾回收器细说---JVM(十四)
阅读量:495 次
发布时间:2019-03-07

本文共 1556 字,大约阅读时间需要 5 分钟。

JVM垃圾收集器深入理解

串行收集器(Serial GC)

串行收集器是JVM中最基础、历史悠久的垃圾收集器,曾是JDK1.3之前唯一的新生代垃圾收集选项。以下是其关键特性:

  • 工作机制:采用复制算法和“停止世界”(Stop-the-World)机制,执行内存回收。
  • 适用场景
    • 在Client模式下,HotSpot虚拟机的默认新生代垃圾收集器。
    • 适用于内存量较小(几十MB至一两百MB)的桌面应用场景,是选择的良好方案。
    • 性能优势:在单线程环境下,避免线程切换开销,实现最高单线程垃圾回收效率。
    • 配置建议:通过-XX:+UseSerialGC参数指定年轻代和老年代使用串行收集器。

    串行旧生代收集器(Serial Old GC)

    串行旧生代收集器是串行收集器在老年代垃圾回收中的版本,采用相同的串行回收和“停止世界”机制,使用标记-压缩算法。主要用途:

    • Client模式下的老年代垃圾回收默认选择。
    • Server模式中,与新生代的并行收集器配合使用,或作为CMS收集器的后备方案。

    并行收集器(Parallel GC)

    并行收集器是串行收集器的多线程版本,专门用于新生代垃圾回收,特点有:

  • 工作机制:采用复制算法和“停止世界”机制,同时支持并行回收。
  • 适用场景
    • 新生代垃圾回收,适合多CPU环境,充分利用多核资源。
    • 在服务器环境中,通过高吞吐量优化应用程序性能。
  • 性能优化:支持自适应调节策略,自动调整垃圾回收参数。
  • 配置建议
    • 使用-XX:+UseParallelGC手动指定新生代使用并行收集器。
    • 通过-XX:ParallelGCThreads设置并行回收线程数,默认与CPU核数一致。
  • 参数优化:使用-XX:+UseAdaptiveSizePolicy开启自适应调节策略,达到内存堆和吞吐量的平衡。
  • 吞吐量优先收集器(Parallel Scavenge)

    Parallel Scavenge收集器专注于高吞吐量,其主要特点是:

  • 工作机制:采用复制算法和并行回收,支持老年代的Parallel Old收集器。
  • 适用场景:适合需要长时间运行且对应用程序性能有严格要求的吞吐量优先场景。
  • 老年代垃圾回收:通过Parallel Old收集器,采用标记-压缩算法。
  • 优化优势:通过自动调节策略,平衡内存使用、吞吐量和停顿时间。
  • 默认配置:JDK8及以上版本默认使用Parallel Scavenge作为老年代垃圾收集器。
  • CMS收集器(Concurrent Mark Sweep GC)

    CMS收集器作为HotSpot虚拟机的第一款并发垃圾收集器,以低延迟著称:

  • 工作机制:采用标记-清除算法,并在并发清除阶段与用户线程同时运行,减少“停止世界”时间。
  • 适用场景:优化互联网站或B/S系统等高并发场景的服务响应速度。
  • 内存管理:通过动态 Adjustment 保证应用程序有足够内存可用,避免“Concurrent Mode Failure”失败。
  • 可选项参数
    • 设置-XX:CMS Initiating Occupancy Fraction老年代触发回收阈值。
    • 使用-XX:+UseCMSCompactAtFullCollection优化内存碎片。
    • 设置-XX:CMSFullGCsBeforeCompaction触发内存压缩次数。
    • 通过-XX:ParallelCMSThreads设置并发线程数,平衡性能与资源消耗。
  • 收集器选择与优化

    选择合适的垃圾收集器取决于具体需求:

  • 最小化内存占用与并行开销:选择Serial GC
  • 最大化吞吐量:选择Parallel GC
  • 最小化GC中断时间:选择CMS GC
  • 通过合理配置垃圾收集器参数,可以根据应用场景的具体需求平衡垃圾回收性能与应用性能,实现高效内存管理。

    转载地址:http://wuacz.baihongyu.com/

    你可能感兴趣的文章
    nvm切换node版本
    查看>>
    nvm安装以后,node -v npm 等命令提示不是内部或外部命令 node多版本控制管理 node多版本随意切换
    查看>>
    ny540 奇怪的排序 简单题
    查看>>
    NYOJ 1066 CO-PRIME(数论)
    查看>>
    NYOJ 737:石子合并(一)(区间dp)
    查看>>
    nyoj------203三国志
    查看>>
    nyoj58 最少步数
    查看>>
    OAuth 及 移动端鉴权调研
    查看>>
    OAuth2 + Gateway统一认证一步步实现(公司项目能直接使用),密码模式&授权码模式
    查看>>
    OAuth2 Provider 项目常见问题解决方案
    查看>>
    OAuth2 vs JWT,到底怎么选?
    查看>>
    Vue.js 学习总结(14)—— Vue3 为什么推荐使用 ref 而不是 reactive
    查看>>
    oauth2-shiro 添加 redis 实现版本
    查看>>
    OAuth2.0_JWT令牌-生成令牌和校验令牌_Spring Security OAuth2.0认证授权---springcloud工作笔记148
    查看>>
    OAuth2.0_JWT令牌介绍_Spring Security OAuth2.0认证授权---springcloud工作笔记147
    查看>>
    OAuth2.0_介绍_Spring Security OAuth2.0认证授权---springcloud工作笔记137
    查看>>
    OAuth2.0_完善环境配置_把资源微服务客户端信息_授权码存入到数据库_Spring Security OAuth2.0认证授权---springcloud工作笔记149
    查看>>
    OAuth2.0_授权服务配置_Spring Security OAuth2.0认证授权---springcloud工作笔记140
    查看>>
    OAuth2.0_授权服务配置_令牌服务和令牌端点配置_Spring Security OAuth2.0认证授权---springcloud工作笔记143
    查看>>
    OAuth2.0_授权服务配置_客户端详情配置_Spring Security OAuth2.0认证授权---springcloud工作笔记142
    查看>>