Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

What is the Metadata GC Threshold and how do I tune it?

In an application I have the following -verbose:gc

[GC (Metadata GC Threshold)  8530310K->2065630K(31574016K), 0.3831399 secs] [Full GC (Metadata GC Threshold)  2065630K->2053217K(31574016K), 3.5927870 secs] [GC (Metadata GC Threshold)  8061486K->2076192K(31574016K), 0.0096316 secs] [Full GC (Metadata GC Threshold)  2076192K->2055722K(31574016K), 0.9376524 secs] [GC (Metadata GC Threshold)  8765230K->2100440K(31574016K), 0.0150190 secs] [Full GC (Metadata GC Threshold)  2100440K->2077052K(31574016K), 4.1662779 secs] 

What is this "Metadata GC threshold" and how to I reduce it. Note: while the Full GC spends a long time cleaning up, it does not actually clean up much, i.e. it would be better if it didn't do this.

like image 444
Peter Lawrey Avatar asked Aug 11 '14 19:08

Peter Lawrey


People also ask

What is XX MetaspaceSize?

Description. -XX:MetaspaceSize specifies the standard value for full GCs that originate in the Metaspace area. The Metaspace area stores the class information that was loaded. You can estimate the size of the Metaspace area based on the size of the class information required for applications.

What is Gc allocation failure?

A GC allocation failure means that the garbage collector could not move objects from young gen to old gen fast enough because it does not have enough memory in old gen. This can cause application slowness.


2 Answers

The log message tells that GC was caused by Metaspace allocation failure. Metaspaces hold class metadata. They have appeared in Java 8 to replace PermGen.

Here are some options to tune Metaspaces.
You may want to set one or several of the following options:

-XX:MetaspaceSize=100M Sets the size of the allocated class metadata space that will trigger a garbage collection the first time it is exceeded;

-XX:InitialBootClassLoaderMetaspaceSize=32M to increase the boot class loader Metaspace;

-XX:MinMetaspaceFreeRatio=50 to make Metaspaces grow more agressively;

-XX:MaxMetaspaceFreeRatio=80 to reduce the chance of Metaspaces shrinking;

-XX:MinMetaspaceExpansion=4M the minumum size by which a Metaspace is exanded;

-XX:MaxMetaspaceExpansion=16M the maximum size to expand a Metaspace by without Full GC.

like image 186
apangin Avatar answered Oct 06 '22 08:10

apangin


While there is already an accepted answer, wanted to mention that there is also :

-XX:MaxMetaspaceSize=<NNN> where <NNN> is the maximum amount of space to be allocated for class metadata (in bytes).

Also from here,

Garbage collection of the dead classes and classloaders is triggered once the class metadata usage reaches the “MaxMetaspaceSize”.

There is a list of available options in this post.

like image 27
Ravindra HV Avatar answered Oct 06 '22 08:10

Ravindra HV