<div dir="ltr">Hello,<div><br></div><div>I'm using JDK 11.0.13 and G1GC. Our application needs to dynamically load lots of classes so I'm monitoring our metaspace usage. I noticed that the high watermark can exceed the MaxMetaspaceSize and I wonder whether this is expected behavior? Any suggestions would be appreciated!</div><div><br></div><div>Below is the output of jcmd VM.metaspace:</div><div><br></div><div>Total Usage ( 35182 loaders):<br><br>  89645 chunks,   383.36 MB capacity,   340.29 MB ( 89%) used,    37.58 MB ( 10%) free,    19.78 KB ( <1%) waste,     5.47 MB (  1%) overhead, deallocated: 52608 blocks with 17.04 MB<br><br>Virtual space:<br>    628.00 MB reserved,     627.25 MB (>99%) committed<br><br><br><br>Chunk freelist:<br><br> specialized chunks:    3, capacity 3.00 KB<br>       small chunks: 30762, capacity 120.16 MB<br>      medium chunks: 1976, capacity 123.50 MB<br>   humongous chunks: (none)<br>              Total: 32741, capacity=243.67 MB<br><br>Waste (percentages refer to total committed size 627.25 MB):<br>              Committed unused:    228.00 KB ( <1%)<br>        Waste in chunks in use:     19.78 KB ( <1%)<br>         Free in chunks in use:     37.58 MB (  6%)<br>     Overhead in chunks in use:      5.47 MB ( <1%)<br>                In free chunks:    243.67 MB ( 39%)<br>Deallocated from chunks in use:     17.04 MB (  3%) (52608 blocks)<br>                       -total-:    304.00 MB ( 48%)<br><br><br>MaxMetaspaceSize: 768.00 MB<br>InitialBootClassLoaderMetaspaceSize: 4.00 MB<br>UseCompressedClassPointers: false<br>No class space<br>Initial GC threshold: 512.00 MB<br>Current GC threshold: 836.34 MB<br>CDS: off<br clear="all"><div><br></div>-- <br><div dir="ltr" class="gmail_signature" data-smartmail="gmail_signature"><div dir="ltr"><div><div dir="ltr"><div>Best regards!</div>
<div>Rui Li</div></div></div></div></div></div></div>