0

我正在使用 JBoss 7.1.3、JDK 1.6 和 Mac 10.9.1。在使用 Maven Jboss AS 插件对我的 WAR 文件进行多次部署/取消部署后,我的服务器因以下错误而死机……

15:05:10,120 ERROR [org.xnio.listener] (Remoting "daves-macbook-pro:MANAGEMENT" read-1) A channel event listener threw an exception: java.lang.OutOfMemoryError: PermGen space

sudo jmap -dump:format=b,file=/tmp/leak 16274
sudo jhat -J-Xmx2048m /private/tmp/leak

但是当我访问结果页面http://locohost.mymachine.com:7000/(除了它说“localhost”而不是“locohost.mymachine.com”)时,输出完全难以辨认。例如,有很多行引用了我们编写的类

Package org.mainco.subco.myproject.interaction.domain
class org.mainco.subco.myproject.interaction.domain.Note [0x2d145258]
class org.mainco.subco.myproject.interaction.domain.NoteDto [0x2a8de180]
class org.mainco.subco.myproject.interaction.domain.Note_ [0x2baa5980]

但是我如何将其追溯到导致这些 PermGen 错误的部分代码?

4

1 回答 1

0

如果您想追踪类加载器泄漏,我建议您使用比 jmap 和 jhat 更高级的工具 - 例如 Eclipse Memory Analyzser (MAT)。以下是如何进行此类分析的分步指南。它是一个博客系列的一部分,解释了您在代码中可能犯的不同错误,以及可能触发问题的第三方库列表。

如果您想解决这个问题,还有一个防泄漏库。

于 2014-03-05T14:44:31.900 回答