Request for review (S): 7163848: G1: Log GC Cause for a GC
Bengt Rutisson
bengt.rutisson at oracle.com
Tue Apr 24 12:12:23 UTC 2012
Hi everyone,
Could I have a couple of reviews for this change?
http://cr.openjdk.java.net/~brutisso/7163848/webrev.00/
Background
Many times it is useful to know why a GC happened. The GC cause tells us
that, but it has not been exposed in the log file before. The change
adds that information to the log entries for PrintGC.
Here are some examples of what the logging looks like with this change:
[GC pause (young) (G1 Evacuation Pause) 149M->118M(244M), 0.2433432 secs]
[GC pause (young) (initial-mark) (G1 Evacuation Pause) 160M->128M(247M),
0.1768634 secs]
[GC pause (young) (initial-mark) (G1 Humongous Allocation)
32M->32M(100M), 0.0104583 secs]
[GC pause (mixed) (G1 Evacuation Pause) 128M->82M(256M), 0.5632070 secs]
[Full GC (System.gc()) 417K->321K(100M), 0.0324733 secs]
[Full GC (Permanent Generation Full) 285K->285K(7168K), 0.0270867 secs]
[Full GC (Last ditch collection) 285K->275K(7168K), 0.0268307 secs]
[Full GC (No GC)[GC concurrent-root-region-scan-end, 0.0007064]
We might want to re-phrase the GC cause names, but that should probably
be a separate CR since it will affect jstat and others that use the
GCCause::to_string() method.
Thanks,
Bengt
More information about the hotspot-gc-dev
mailing list