JVM快速调优手册04:堆内存分配的CMS公式解析

一.JVM 堆内存组成

Java堆由Perm区和Heap区组成,Heap区由Old区和New区(也叫Young区)组成,New区由Eden区、From区和To区(Survivor)组成。

437d1aa4b493e07180802184cccd6bfee60.jpg
Eden区用于存放新生成的对象。Eden中的对象生命不会超过一次Minor GC。

Survivor Space  有两个,存放每次垃圾回收后存活的对象,即图的S0和S1。

Old Generation  Old区,也称老生代,主要存放应用程序中生命周期长的存活对象

二.公式

将EDEN与From survivor中的存活对象存入To survivor区时,To survivor区的空间不足,

再次晋升到old gen区,而old gen区内存也不够的情况下产生了promontion faild从而导致full gc.那可以推断出:eden+from survivor < old gen区剩余内存时,

不会出现promontion faild的情况。

即:

(Xmx-Xmn)*(1-CMSInitiatingOccupancyFraction/100)>=(Xmn-Xmn/(SurvivorRatior+2))

进而推断出:

CMSInitiatingOccupancyFraction <=((Xmx-Xmn)-(Xmn-Xmn/(SurvivorRatior+2)))/(Xmx-Xmn)*100

Xmx-Xmn:Old区大小。

CMSInitiatingOccupancyFraction/100:Old区百分之多少时,cms开始gc

1-CMSInitiatingOccupancyFraction/100: Old区开始gc回收时剩余空间百分比

(Xmx-Xmn)*(1-CMSInitiatingOccupancyFraction/100): Old区开始gc回收时剩余空间大小

(Xmn-Xmn/(SurvivorRatior+2)): eden+from survivor区的大小

三.参数:

-Xmx :java heap最大值。建议均设为物理内存的80%。不可超过物理内存。

-Xmn:java heap最小值,一般设置为Xmx的3、4分之一,等同于-XX:NewSize 和 -XX:MaxNewSize  ,其实为young区大小。

-XX:CMSInitiatingOccupancyFraction=70 :使用cms作为垃圾回收使用70%后开始CMS收集。

-XX:SurvivorRatio=2: 生还者池的大小,默认是2。

转载于:https://my.oschina.net/gordonnemo/blog/3028959

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值