是什么导致 JBoss 上的 PermGen OutOfMemoryError?

Pet*_*ton 8 jboss permgen outofmemoryerror

JBoss 中 PermGen OutOfMemoryError 的根本原因是什么?

我在我的开发环境中运行 JBoss AS 4.2.2,这是在多次重新部署我的 Web 应用程序后发生的。

Christian Vest Hansen 的博客给出的 JVM 选项很有帮助,但并没有完全解决问题:

-XX:+UseConcMarkSweepGC
-XX:+CMSPermGenSweepingEnabled
-XX:+CMSClassUnloadingEnabled
-XX:MaxPermSize=128m
Run Code Online (Sandbox Code Playgroud)

fal*_*tro 5

如前所述,您可能会遇到泄漏的类加载器。由于某种原因,您的课程没有被卸载。这可能有两个原因

  • 所述类的对象仍然存在于堆上,对象总是引用它们的类,或者
  • 类加载器在某处被引用,无论出于何种原因,类加载器引用它们的类是为了不加载它们两次

这个问题没有包罗万象的解决方案。帮助您找到根本原因的一个有用工具是Eclipse Memory Analyzer Tool,您可以将其应用于来自 JVM 的堆转储(您可以使用 -XX:+HeapDumpOnOutOfMemoryError 选项在 OOM 上启用堆转储)。也许开始从您的 Web 应用程序中查找 java.lang.Class 对象,以了解它们为何保持活动状态。不幸的是,永久代通常不是 JVM 堆转储的一部分,因此您只能尝试在堆的其余部分中找到相关的工件(如果我没记错,类对象不会存储在永久代中,只有实际的字节码是,请如果我错了,请纠正我)。

哈。

编辑:
Dave Cheney 在评论中建议 java.lang.Class-objects 确实是 PermGen 的一部分,并且不包含在正常的热点堆转储中。除非您有一个 JVM 在堆转储中写入此信息,否则您将需要不同的方法。您仍然可以查找对象的实例,但是如果您泄漏了类/类加载器(不幸的是,它们都相互暗示),似乎您需要寻找其他标志(来自 JBoss 的元数据对象等)。