我正在使用Tomcat来部署具有以下PermGen配置的Web应用程序:
JAVA_OPTS="-Djava.awt.headless=true -Dfile.encoding=UTF-8
-server -Xms1536m -Xmx1536m
-XX:NewSize=256m -XX:MaxNewSize=256m -XX:PermSize=256m
-XX:MaxPermSize=256m -XX:+DisableExplicitGC"
请知道以下内容:
另外请注意,我有3个拥有相同PermGen配置的Tomcats,运行在8 GB Ram的同一物理服务器上,这让我害怕将PermGen max size增加到512MB而不影响物理服务器内存。
答案 0 :(得分:3)
Tomcat中的Permgen OOME通常由两部分组成:
热重新部署。
内存泄漏,其中某些引用会导致旧的类加载器及其所有依赖对象保持可访问状态。
因此,有两种方法可以避免这个问题:
不要进行热重新部署。或者重新开始每一次热重复活动。
追踪并修复与类加载器相关的存储泄漏。
增加permgen大小不会阻止问题,但可能会增加OOME问题之间的间隔。 (或者允许您不经常执行完整的Tomcat关闭/重启。)
你的问题:
1)Tomcat使用的整个内存是256MB还是Tomcat因其他原因占用其他内存?
见上文。它不是专门的Tomcat,尽管Tomcat特别容易出现这种情况。 (显然,Hibernate可能也是......我相信它应用于动态代理的使用。)
2)如何监控Tomcat使用的内存以避免达到PemGen max size?
有多种方法可以监控内存使用情况;例如附加代理人。但是,这些并不能解决问题。 IMO,更改生产服务器的管理程序会更简单,这样您就不需要进行热重新部署。
答案 1 :(得分:0)
Tomcat需要增加permgen不是为了满足自己的需求,而是因为它可以运行多个webapps,它们都会加载自己的类(permgen主要用于存储类)。您也可以使用jconsole util查看内存使用情况,转到内存 - >图表 - >内存池Perm Gen.对于我刚开始没有用户webapps的Tomcat 7,它显示65M最大6M使用。