G1收集器优化总结

         随着jdk的升级,原CP+CMS的垃圾回收机制 被G1替代,从jdk11开始默认为G1垃圾回收。

G1垃圾回收原理

        将内存分为2048个块,每块大小为1-32M,所以jvm的内存一定是2G-64G,所以如果内存不再此范围内需要进行复杂调参(不用G1更好)。对象存储在每个块中(region),会按块进行标记内存回收

edengc:初始标记为eden区,当到达一定阈值时进行回收,满阈值(8)到老年代

mixgc: eden和old一起标记,引用或满阈值标记到老年代,该回收回收,但不超过配置的

-XX:MaxGCPauseMillis 

fullgc: 一定要GC完

因为region本身不区分是否是old,所以不存在物理上的 年轻代 老年代,但也会逻辑上控制,默认eden的region在10%--60%之间,用以提高性能,但具体多少是根据GC情况动态调整的

参数优化

        根据以上,G1是一个自动调优的算法,主要影响参数:内存大小,暂停毫秒数

所以关键参数为:-Xms -Xmx -XX:MaxGCPauseMillis

因为时并发标记,而且有指定暂停时间,所以在高并发场景下,将参数值往大调即可,当然到达原CMS那种调优结果(如可控稳定fullGC)是很难的

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值