在我们的 Wildfly 10 应用服务器上,我们将 groovy 用于 jasperreports 和其他类似系统。
一段时间后,jvm(java 8)收到“内存不足:元空间”错误。
同样的问题发生在一些带有 permgen (java 6) 的旧 jboss 4 服务器上。
我们将jasperreports从3.7.2升级到6.3.1,问题依旧。
permgen/metaspace 的大小足够大(最大 512 MB)。
我们其他不使用 jasperreports 和 groovy 的应用程序没有这个问题。
经过一些研究,我意识到这可能是类加载器( stackoverflow question )中的内存泄漏。似乎 gc 不会卸载从 groovy 生成的类。
在 jaspersoft documentation他们写道,你应该设置 -XX:+UseConcMarkSweepGC
和 -XX:+CMSClassUnloadingEnabled
作为 VM 参数以启用类卸载。
所以我们改变了它,但问题仍然存在。
Java 8 是否仍然支持这些参数?如果没有,是否还有其他解决方案。
目前我们必须每晚重启服务器才能避免这个问题。
最佳答案
正如 Durandal 在问题的评论中提到的,堆转储中有很多“sun/reflect/DelegatingClassLoader”和“org/codehaus/groovy/runtime/callsite/CallSiteClassLoader”条目。看起来 groovy 有一些内存泄漏问题。我们将脚本引擎从 groovy 更改为用于 jasper 报告的 java 和用于我们其他系统的 javascript。这解决了问题。谢谢您的帮助。
关于java - 内存不足 : metaspace with wildfly and groovy/jasper,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40058959/