我使用的是JBoss 7.1.3、JDK1.6和Mac10.9.1。在使用Maven Jboss作为插件对我的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错误的代码部分呢?
发布于 2014-03-05 22:44:32
如果你想追踪类加载器泄漏,我建议你使用一些比jmap和jhat更高级的工具--比如Eclipse Memory Analyzser (MAT)。Here是如何进行此类分析的逐步指南。这是一个博客系列的一部分,它解释了你在代码中可能犯下的不同错误,以及可能引发问题的第三方库的列表。
如果你想解决这个问题,还有一个Leak prevention library。
https://stackoverflow.com/questions/22183382
复制相似问题