G1GC, Java8u40ea, Metaspace questions
Wolfgang Pedot
wolfgang.pedot at finkzeit.at
Thu Feb 19 10:37:03 UTC 2015
Hi
Am 18.02.2015 05:12, schrieb Yu Zhang:
> Hi,
>
> After discussing with the developers, here is the explanation:
> >shows a slow but continuous increase of the "commited" value for
> Metaspace even though "used" after a collect is quite stable and
> "commited" is shrunk after every collect.
>
> This might be due to fragmentation in metadata space. Even though the
> total used is stable, the memory is fragmented so it has to allocate
> more. If you have Flight Recorder(a commercial feature), you can see
> this information in JFR.
Unfortunately I do not have JFR available, however I did notice that the
number of classes that fit into Metaspace before the collect also kept
increasing so it cant all be fragmentation.
> >I have found out that I need to set Min and MaxMetaspaceFreeRatio
> really really low (like <=10%) to keep the high-water-mark in check
> and I dont quite see why in the numbers.
>
> This might be related to how the high water mark is calculated. There
> are some ways to improve this but not implemented yet.
The more I test the more I come to the conclusion that there is
something strange about that calculation (or my understanding of it). I
am currently running a very long test on 64bit linux (>9million classes
loaded so far) and there is a definite upwards trend of both the HWM and
used-after-GC. Class unloading does not seem to be as successful when a
concurrent cycle is triggered by Metaspace threshold compared to a
Full-GC and that gap is growing over time. I guess thats because the
heap of the test-JVM is rather large and empty and since G1 is allowed
to waste 5% if it that means some classloaders stay alive longer
although that should stabilize at some point. Increasing the usage in
oldGen from ~0.5GB to ~1GB made class unloading "better" for one collect.
The high-point of Metaspace usage slowly increased from ~400MB to ~600MB
during the first part of the test and used-after-GC started at 200MB and
crept up to around 400MB. I decided to throw in a manual FullGC during
the test to see what happens and that brought the usage down to ~110MB
as it should be so there is no real class-leak. Since
MaxMetaspaceFreeRatio is configured to 30% (Min is 10%) I would have
expected the HWM to go down after that collect but appearantly it did
not, it stayed at ~600MB for the next collect and then went up another
~50MB.
I dont really see the HWM-value so when I write "HWM" I am referring to
the highest point of Metaspace-usage before a collect is initiated.
I have attached a screenshot of jconsole showing the part with the
FullGC (~9:40), I reconnected to the JVM at ~8:55 so it does not cover
the whole uptime.
Is this expected or explainable behaviour? The way I see it the high
points of that curve may keep on climbing until they hit the limit and
after that its FullGCs all the time.
regards
Wolfgang
-------------- next part --------------
A non-text attachment was scrubbed...
Name: jconsole_8u40_2048_30_10_fullgc.png
Type: image/png
Size: 102718 bytes
Desc: not available
URL: <http://mail.openjdk.java.net/pipermail/hotspot-gc-use/attachments/20150219/a80932df/jconsole_8u40_2048_30_10_fullgc-0001.png>
More information about the hotspot-gc-use
mailing list