我正在运行的Java进程在开始的头一个小时内始终运行良好,因此它可以运行。但是,性能随后迅速下降。分析时,我发现元空间垃圾收集相当频繁地发生,直到小时标记,然后才失控:

Java 8元空间垃圾回收-LMLPHP

我相当确定我可以使用-XX:MaxMetaspaceSize选项来解决此问题。但是,我想更多地了解为什么可能会发生此行为。我无法想象为什么垃圾回收算法会像这样表现。有人对更好的解决方案有解释或建议吗?谢谢

最佳答案

您可以尝试设置-XX:MaxMetaspaceExpansion=0。在尝试增加元空间之前,这将强制使用完整的GC-释放动态创建的方法/类数据。另外,您可以尝试将MaxMetaspaceFreeRatio设置为比默认值低的值,以在GC之后进一步缩小元空间本身。

有关其他与元空间有关的选项,请参见this answer

元空间收集本身依赖于垃圾收集器正在卸载的类。因此,根据GC的不同,您可能会进行调整以尽早回收垃圾也可能有所帮助。

关于Java 8元空间垃圾回收,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/31587732/

10-10 09:07