RFR (S): 8019902: G1: Use the average heap size rather than the minimum heap size to calculate the region size
Bengt Rutisson
bengt.rutisson at oracle.com
Thu Aug 29 14:14:33 UTC 2013
Tony,
On 8/29/13 4:12 PM, Tony Printezis wrote:
> Bengt,
>
> Doesn't what I said also applies for users who do not set -Xms? So, if
> -Xms is by default 6m, a user launches the VM with:
>
> java -Xmx32G ...
>
> and the region size is calculated to be 8m, what's the initial heap
> size (8m, i.e. one region)?
No, by default we calculate a reasonable -Xms. So as long as the policy
uses that value and not the min heap size I think we are fine.
Bengt
>
> Tony
>
> On 8/29/13 10:08 AM, Bengt Rutisson wrote:
>>
>> Hi Tony,
>>
>> Thanks for looking at this!
>>
>> Comments inline.
>>
>> On 8/29/13 3:03 PM, Tony Printezis wrote:
>>> Hi Bengt,
>>>
>>> Yeah, I struggled with this heuristic when I did the original
>>> implementation of the heap region calculation. The issue only arises
>>> when the gap between the min and max heap size is very large. So, if
>>> someone launches the VM with:
>>>
>>> java -Xms32m -Xmx64g ...
>>>
>>> and G1 picks a region size of 8m, it'd start with only 4 regions
>>> which will probably make performance right at the beginning will be
>>> terrible (but I agree that it will be better as the heap grows,
>>> compared to if an 1m region size was used).
>>
>> Agreed. And just to be clear. The main problem with the existing
>> policy is that it by default always picks 1m regions if nothing is
>> set on the command line. This is due to the fact that it is not based
>> on the initial heap size (-Xms) but on the min heap size, which by
>> default is in the order of 6m. So, those who set -Xms on the command
>> line have experienced less of a problem. At least if they set -Xms to
>> high enough values.
>>
>>>
>>> Can I suggest maybe an additional policy change? Use the avg to
>>> calculate the region size, as you proposed, but potentially adjust
>>> the min heap size based on a min region number (let's pick a number
>>> of a hat: 16; you might want to revise this). So, in the above example:
>>>
>>> -Xms32m -Xmx64g -> region size = 8m
>>>
>>> you'll actually adjust the min heap size 16 x 8m = 128m. This will
>>> avoid the potentially bad behavior right at the start. Of course,
>>> you'll start with a larger heap size than what the user asked for.
>>> On the other hand, if someone uses a huge max they probably expect
>>> the heap to grow. So starting with a large min might be OK.
>>
>> I see your point, but I don't really like the fact that if someone
>> explicitly sets -Xms on the command line we would ignore that and use
>> a value that is four times as large. Also, there is the possibility
>> to set the region size using G1HeapRegionSize on the command line.
>> So, in this use case I kind of think it would be better to leave it
>> up to the user to indicate if the heap is more likely to be 32m or
>> 64g by setting the region size explicitly.
>>
>> Thanks,
>> Bengt
>>
>>>
>>> Tony
>>>
>>> On 8/29/13 5:26 AM, Bengt Rutisson wrote:
>>>>
>>>> Hi everyone,
>>>>
>>>> Could I have a couple of reviews of this change:
>>>>
>>>> http://cr.openjdk.java.net/~brutisso/8019902/webrev.00/
>>>>
>>>> The fact that G1 by default bases its region size on the minimum
>>>> heap size means that out of the box the region size will always be
>>>> 1M. This is a problem on large machines with lots of memory. We
>>>> pick a large heap size but get a very small region size. The small
>>>> regions are inefficient and cause a lot of memory footprint.
>>>> Normally we aim to get around 2048 regions, but on a machine with a
>>>> lot of memory we might pick a default max heap size of 32G, which
>>>> means that we will get ~32000 regions. This can lead to out of
>>>> memory situations - especially on Solaris x86.
>>>>
>>>> This patch changes the heuristics for picking the region size to
>>>> use the average between initial heap size (-Xms) and the maximum
>>>> heap size (-Xmx). This means that for large heaps we will pick
>>>> larger region sizes. In the 32G example we will now pick a region
>>>> size of 8m which means that we will have 4000 regions which is more
>>>> reasonable.
>>>>
>>>> Thanks,
>>>> Bengt
>>>
>>
>
More information about the hotspot-gc-dev
mailing list