JVM垃圾收集相关常用参数

本文详细介绍了JVM中各种垃圾回收器的配置参数及其作用,包括Serial、ParNew、CMS、Parallel Scavenge和Parallel Old等收集器的组合使用方式,并解释了如何通过调整参数来优化内存回收效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 参  数

描  述

UseSerialGC

虚拟机运行在Client模式下的默认值,打开此开关后,使用Serial+
SerialOld的收集器组合进行内存回收

UseParNewGC

打开此开关后,使用ParNew+SerialOld的收集器组合进行内存回收

UseConcMarkSweepGC

打开此开关后,使用ParNew+CMS+SerialOld的收集器组合进行内存
回收。SerialOld收集器将作为CMS收集器出现ConcurrentModeFailure失败后的后备收集器使用

UseParallelGC

虚拟机运行在Server模式下的默认值,打开此开关后,使用Parallel
Scavenge+SerialOld(PSMarkSweep)的收集器组合进行内存回收

UseParallelOldGC

打开此开关后,使用ParallelScavenge+ParallelOld的收集器组合进行内存回收

SurvivorRatio

新生代中Eden区域与Survivor区域的容量比值,默认为8,代表
Eden:Survivor=8∶1

PretenureSizeThreshold

直接晋升到老年代的对象大小,设置这个参数后,大于这个参数的对象
将直接在老年代分配

MaxTenuringThreshold

晋升到老年代的对象年龄。每个对象在坚持过一次MinorGC之后,年
龄就加1,当超过这个参数值时就进入老年代

UseAdaptiveSizePolicy

动态调整Java堆中各个区域的大小以及进入老年代的年龄

HandlePromotionFailure

是否允许分配担保失败,即老年代的剩余空间不足以应付新生代的整个
Eden和Survivor区的所有对象都存活的极端情况

ParallelGCThreads

设置并行GC时进行内存回收的线程数

GCTimeRatio

GC时间占总时间的比率,默认值为99,即允许1%的GC时间。仅在
使用ParallelScavenge收集器时生效

MaxGCPauseMillis

设置GC的最大停顿时间。仅在使用ParallelScavenge收集器时生效

CMSInitiatingOccupancyFraction

设置CMS收集器在老年代空间被使用多少后触发垃圾收集。默认值为
68%,仅在使用CMS收集器时生效

UseCMSCompactAtFullCollection

设置CMS收集器在完成垃圾收集后是否要进行一次内存碎片整理。仅
在使用CMS收集器时生效

CMSFullGCsBeforeCompaction

设置CMS收集器在进行若干次垃圾收集后再启动一次内存碎片整理。
仅在使用CMS收集器时生效

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值