G1 垃圾收集器参数配置及调优

本文介绍了G1垃圾收集器,一种区域化、并行-并发、增量式的HotSpot垃圾回收器,其特点是可预测的暂停时间。G1适用于大内存场景,并具有自适应特性,只需设置最大暂停时间目标、最大和最小堆大小即可。欲了解更多调优细节,可参考官方文档。

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

列表为 G1 GC垃圾收集器常用配置参数:

可选项及默认值描述
-XX:+UseG1GC采用 Garbage First (G1) 收集器
-XX:MaxGCPauseMillis=n设置最大GC 暂停时间。这是一个大概值,JVM 会尽可能的满足此值
-XX:InitiatingHeapOccupancyPercent=n

设置触发标记周期的 Java 堆占用率阈值。默认占用率是整个 Java 堆的 45%。默认值 45.

-XX:NewRatio=nnew/old 年代的大小比例. 默认值 2.
-XX:SurvivorRatio=neden/survivor 空间的大小比例. 默认值 8.
-XX:MaxTenuringThreshold=n对象晋升年代的最大阀值。默认值 15.这个参数需要注意的是:最大值是15,不要超过这个数啊,要不然会被人笑话。原因为:JVM内部使用 4 bit (1111)来表示这个数。
-XX:ParallelGCThreads=n设置在垃圾回收器的并行阶段使用的线程数。默认值因与 JVM 运行的平台而不同。
-XX:ConcGCThreads=n并发垃圾收集器使用的线程数。默认值因与 JVM 运行的平台而不同。
-XX:G1ReservePercent=n设置作为空闲空间的预留内存百分比以降低晋升失败的可能性。默认值10
-XX:G1HeapRegionSize=n使用G1,Java堆被划分为大小均匀的区域。这个参数配置各个子区域的大小。此参数的默认值根据堆大小的人工进行确定。最小值为 1Mb 且最大值为 32Mb。
-XX:G1PrintRegionLivenessInfo默认值false, 在情理阶段的并发标记环节,输出堆中的所有 regions 的活跃度信息
-XX:G1PrintHeapRegions默认值false, G1 将输出那些 regions 被分配和回收的信息
-XX:+PrintSafepointStatistics输出具体的停顿原因
-XX: PrintSafepointStatisticsCount=1输出具体的停顿原因
-XX:+PrintGCApplicationStoppedTime停顿时间输出到GC日志中
-XX:-UseBiasedLocking取消偏向锁
-XX:+UseGCLogFileRotation开启滚动日志输出,避免内存被浪费
-XX:+PerfDisableSharedMem关闭 jstat 性能统计输出特性,使用 jmx 代替
-XX:InitiatingHeapOccupancyPercent设置触发标记周期的 Java 堆占用率阈值。默认占用率是整个 Java 堆的 45%

G1 GC 是区域化、并行-并发、增量式垃圾回收器,相比其他 HotSpot 垃圾回收器,可提供更多可预测的暂停。增量的特性使 G1 GC 适用于更大的堆,在最坏的情况下仍能提供不错的响应。G1 GC 的自适应特性使 JVM 命令行只需要软实时暂停时间目标的最大值以及 Java 堆大小的最大值和最小值,即可开始工作。

调优相关可以参考:https://www.oracle.com/technetwork/cn/articles/java/g1gc-1984535-zhs.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值