RFR(S): 8010780: G1: Eden occupancy/capacity output wrong after a full GC
John Cuthbertson
john.cuthbertson at oracle.com
Wed Mar 27 22:12:49 UTC 2013
Hi Everyone,
Can I have a couple of volunteers look review this fix? The webrev can
be found at: http://cr.openjdk.java.net/~johnc/8010780/webrev.0/
Summary:
One of the performance team spotted and error in the G1 logs following a
full GC:
411.322: [G1Ergonomics (Mixed GCs) (to-space exhausted), 0.4279260 secs]
....
[Eden: 0.0B(1840.0M)->0.0B(1840.0M) Survivors: 0.0B->0.0B Heap:
36.0G(36.0G)->36.0G(36.0G)]
[Times: user=1.13 sys=0.10, real=0.43 secs]
411.336: [Full GC (Allocation Failure) 35G->18G(36G), 8.0471890 secs]
[Times: user=8.50 sys=0.01, real=8.05 secs]
433.639: [GC pause (G1 Evacuation Pause) (young) 433.640: [G1Ergonomics
(CSet Construction) start choosing CSet, _pending_cards: 26203,
predicted base time: 13.50 ms, remaining time: 186.50 ms, target pause
time: 200.00 ms]
433.640: [G1Ergonomics (CSet Construction) add young regions to CSet,
eden: 148 regions, survivors: 0 regions, predicted young region time:
164.22 ms]
433.640: [G1Ergonomics (CSet Construction) finish choosing CSet, eden:
148 regions, survivors: 0 regions, old: 0 regions, predicted pause time:
177.72 ms, target pause time: 200.00 ms]
433.895: [G1Ergonomics (Concurrent Cycles) request concurrent cycle
initiation, reason: occupancy higher than threshold, occupancy:
21458059264 bytes, allocation request: 0 bytes, threshold: 17394617520
bytes (45.00 %), source: end of GC]
, 0.2552910 secs]
....
[Eden: 2368.0M(1840.0M)->0.0B(1632.0M) Survivors: 0.0B->304.0M Heap:
20.7G(36.0G)->20.2G(36.0G)]
The heap transition line for the GC after the full GC was displaying the
eden capacity that was calculated by the GC preceding the full GC rather
than the eden capacity calculated at the end of the of the full GC. As a
result the reported eden occupancy is much larger than the reported
capacity.
The main part of the fix is the moving of
G1CollectorPolicy::_prev_eden_capacity from
G1CollectorPolicy::print_detailed_heap_transition() to
G1CollectorPolicy::record_collection_pause_start(). The code that
records the heap state before the GC has been refactored into a separate
routine and is invoked at the start of both an incremental and full GC.
Additionally I added a more detailed heap transition message to the full
GC output:
> 1.989: [Full GC (Allocation Failure) 256M->234M(256M), 2.3966795 secs]
> [Eden: 0.0B(12.0M)->0.0B(12.0M) Survivors: 0.0B->0.0B Heap:
> 256.0M(256.0M)->234.7M(256.0M)]
> [Times: user=3.00 sys=0.00, real=2.40 secs]
>
for validation purposes.
Testing:
GCOld with a small heap (128m) and +G1PrintHeapRegions
Thanks,
JohnC
More information about the hotspot-gc-dev
mailing list