我正在使用 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 错误的部分代码?