java – 在wildfly上重新部署导致outofmemory:metaspace

我目前正在调查我们最近遇到的元空间问题.其中一个主要原因似乎是在重新部署WAR时加载了重复的类.在本地尝试使用我们的一个WARS,通过完全取消部署之后的堆转储,我可以看到应用程序创建的大多数实例仍然存在(即使在垃圾收集之后).

从堆转储中,我可以看到它似乎是持有引用的ManagedThreadFactoryImpl.

我可以做什么/添加到应用程序关闭过程,以便它自己清理?

我们所有的WAR都是spring应用程序,大多数使用调度/异步元素.

我们在Wildfly 8.2中使用JDK8

解决方法

好像类加载器没有卸载.尝试 Java Mission Control(JMC)并记录用例.这使您可以在录制中转到特定时间点并调试问题.它给出了在特定时间加载的类的快照,包括stacktrace,threaddumps和许多重要的东西.

JMC包含在JDK中.你可以在这里找到更多信息:https://docs.oracle.com/javase/8/docs/technotes/guides/troubleshoot/tooldescr002.html#BABIBBDE

您不必经历采取堆转储的痛苦,然后等待工具分析它.

相关文章

HashMap是Java中最常用的集合类框架,也是Java语言中非常典型...
在EffectiveJava中的第 36条中建议 用 EnumSet 替代位字段,...
介绍 注解是JDK1.5版本开始引入的一个特性,用于对代码进行说...
介绍 LinkedList同时实现了List接口和Deque接口,也就是说它...
介绍 TreeSet和TreeMap在Java里有着相同的实现,前者仅仅是对...
HashMap为什么线程不安全 put的不安全 由于多线程对HashMap进...