Code Review Request: 6819085 G1: use larger and/or user settable region size

Tony Printezis Antonios.Printezis at sun.com
Fri Jul 31 16:04:54 UTC 2009


Vikram,

Hi. With testing we have done so far with 1G-4G heaps, 1m region size 
seemed to work well. However, We have been recently experimenting with 
24g-32g heaps and for that we've seen that larger region sizes are 
beneficial (in order to cut down the number of regions). Which is one of 
the reasons why I worked on this CR. Also note that, after the region 
size calculation you showed, I do bound the region size by 
MIN_REGION_SIZE and MAX_REGION_SIZE. So, the minimum region size, 
currently, will be 1m and in some cases ,we might use a larger one (up 
to currently 32m).

Tony

Vikram A wrote:
> hi Tony,
>
> Just thinking out loud here.
>
> You had once outlined  that we get most benefit with 1MB regions based
> on your testing.
>
>  in arguments.cpp
>
> +   uintx region_size = G1HeapRegionSize;
> +   if (FLAG_IS_DEFAULT(G1HeapRegionSize)) {
> +     // We base the automatic calculation on the min heap size. This
> +     // can be problematic if the spread between min and max is quite
> +     // wide, imagine -Xms128m -Xmx32g. But, if we decided it based on
> +     // the max size, the region size might be way too small for the
> +     // min size. Either way, some users might have to set the region
> +     // size manually for some -Xms / -Xmx combos.
> +     region_size = min_heap_size() / TARGET_REGION_NUMBER;
> +   }
>
> with this for many small application it seems to me that the region
> size is disturbed.
>
> eg. in the above doc. you mention
> -Xms128, consider the heap to be  and TARGET_REGION_NUMBER is defined as 2048.
> So, total heap will be
> 128 * 1024(K) = 131072K
> now dividing 131072K/2048 = 64K for each region.
>
> If this inpterpretation is right and there is a reason for doing it
> this way, aren't we losing the adv we gained with 1024K region.
> this seems like a very small region size and would induce frequent GC,
> although could be with small pause time.
>
> I would assume that many enterprise would run their java with larger
> heaps than this, but considering this is also for every one, should
> the 1024K region size be useful to keep by default while allowing this
> fix to modify it for advanced user.
>
> Like I said just my thoughts.
>
> regards,
> Vikram.
>
> On Fri, Jul 31, 2009 at 2:51 AM, Tony Printezis
> <Antonios.Printezis at sun.com> wrote:
>   
>> http://cr.openjdk.java.net/~tonyp/6819085/webrev.0/
>>
>> The idea is to allow the user to set the region size with a parameter (-XX:G1HeapRegionSize=N).
>>
>> Tony
>>
>> --
>> ----------------------------------------------------------------------
>> | Tony Printezis, Staff Engineer    | Sun Microsystems Inc.          |
>> |                                   | MS BUR02-311                   |
>> | e-mail: tony.printezis at sun.com    | 35 Network Drive               |
>> | office: +1 781 442 0998 (x20998)  | Burlington, MA01803-0902, USA  |
>> ----------------------------------------------------------------------
>> e-mail client: Thunderbird (Solaris)
>>
>>
>>     

-- 
---------------------------------------------------------------------
| Tony Printezis, Staff Engineer   | Sun Microsystems Inc.          |
|                                  | MS UBUR02-311                  |
| e-mail: tony.printezis at sun.com   | 35 Network Drive               |
| office: +1 781 442 0998 (x20998) | Burlington, MA 01803-2756, USA |
---------------------------------------------------------------------
e-mail client: Thunderbird (Linux)





More information about the hotspot-gc-dev mailing list