PermGen Out of Memory原因
我经常在PermGen中检测我的环境中的OOM:
- java 6
- 的jboss-4.2.3
- 不是一个大的网络应用程序
我知道String.intern()问题 – 但我没有足够的宝贵用法。 MaxPermGen尺寸的增加不会产生任何影响(从128 Mb到256 Mb)。
还有什么其他原因可以为PermGen调用OOM? 在这种情况下(战略,工具等),最佳调查方案是什么?
谢谢你的帮助
请参阅此说明
- 将JDBC驱动程序放在common / lib中(如tomcat文档所述)而不是WEB-INF / lib
- 不要将commons-logging放入WEB-INF / lib,因为tomcat已经引导它了
新的类对象被放入PermGen,因此占用了越来越多的空间。 无论你制作PermGen空间有多大,它都将在经过足够的部署后不可避免地达到顶峰。 你需要做的是采取措施冲洗PermGen,以便你可以稳定它的大小。 有两个JVM标志可以处理这种清理:
-XX:+CMSPermGenSweepingEnabled
此设置包括垃圾收集运行中的PermGen。 默认情况下,PermGen空间永远不会包含在垃圾收集中(因此无限制地增长)。
-XX:+CMSClassUnloadingEnabled
此设置告诉PermGen垃圾收集扫描对类对象执行操作。 默认情况下,即使在garabage集合期间访问PermGen空间时,类对象也会获得免除。
在具有类加载器泄漏时重新部署应用程序时通常会出现此错误,因为这意味着在旧版本保留时会再次加载所有类。
有两种解决方案:
- 重新启动应用服务器而不是重新部署应用程序 – 简单但令人讨厌
- 使用分析器调查并修复泄漏。 不幸的是,类加载器泄漏很难确定。