我有一个使用hibernate 3.6.4和
spring 3.2.4(mvc,tx和security)的web应用程序,并且在tomcat 7中运行.每当我部署更新版本的应用程序而不重新启动tomcat时,则使用的内存由tomcat增加约50MB.
我创建了一些堆转储并使用Eclipse Memory Analyzer进行分析.我发现每次重新部署应用程序时,都会创建一个新的WebappClassLoader实例.但即使在我使用tomcat管理器停止应用程序之后,WebappClassLoader仍然保留在内存中,并且不会被垃圾回收.
因此,在每次重新部署之后,额外的WebappClassLoader将保留在内存中并使用大约50MB的内存.
我使用Eclipse Memory Analyzer来查找从WebappClassLoader到GC根的引用路径.在结果中,我找不到任何可能阻止WebappClassLoaders被垃圾回收的强引用.
那么,是什么让WebappClassLoaders保持活力?我可以在哪里调查,以找出什么阻止垃圾收集的WebappClassLoader?
解决方法
理论上,类加载器在没有引用对象实例的情况下是垃圾收集的,并且类卸载不是必需的,但实际上它似乎更有问题.
我建议阅读这两篇文章
http://frankkieviet.blogspot.com.au/2006/10/classloader-leaks-dreaded-permgen-space.html
http://frankkieviet.blogspot.com.au/2006/10/how-to-fix-dreaded-permgen-space.html