don't know what made you believe "System.gc() doesn't trigger old" -- what collector are you<br>using and what makes you believe that's the case? Any representative GC logs to illustrate<br>what you are describing below? Also any details on the JVM/JDK version you are seeing this with?<br>
<br>-- ramki<br><br><div class="gmail_quote">On Wed, Oct 31, 2012 at 3:20 AM, Ashish Saxena <span dir="ltr"><<a href="mailto:anantiitrke@gmail.com" target="_blank">anantiitrke@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Hi Team,<br>
<br>
We are observing that even after multiple full GC, JVM doesn't clear<br>
the Old generation. Full GC do occur (as seem from GC logs), but it<br>
performs Young generation collection followed by promotion into old<br>
generation but the old generation collection doesn't happen.<br>
<br>
Test:<br>
When Heap size is low (1 GB), after multiple full GC, total heap size<br>
after GC is around 400 MB.<br>
But with Heap size is high(8 GB), after multiple full GC, total heap<br>
size after GC is around 1300 MB. GC logs confirms that old generation<br>
is not getting collected.<br>
<br>
It seems that on receiving request for full GC,<br>
1. JVM triggers young generation GC<br>
2. Checks the occupancy of old generation, and triggers Old generation<br>
GC only if there is memory pressure.<br>
<br>
Is there a way by which we can instruct JVM to trigger Old generation<br>
collection each time full GC is triggered ? This is required to<br>
measure actual memory usage (without garbage) of the application.<br>
<br>
Thanks and Regards,<br>
Ashish A. Saxena<br>
</blockquote></div><br>