加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

java Web应用程序中的内存泄漏

发布时间:2020-12-14 06:02:58 所属栏目:Java 来源:网络整理
导读:我有一个使用hibernate 3.6.4和 spring 3.2.4(mvc,tx和security)的web应用程序,并且在tomcat 7中运行.每当我部署更新版本的应用程序而不重新启动tomcat时,则使用的内存由tomcat增加约50MB. 我创建了一些堆转储并使用Eclipse Memory Analyzer进行分析.我发现
我有一个使用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?

我认为可能有一个阻塞的finalize()方法阻止GC完成垃圾收集.但我怎么能检查这个?

解决方法

理论上,类加载器在没有引用对象实例的情况下是垃圾收集的,并且类卸载不是必需的,但实际上它似乎更有问题.

我建议阅读这两篇文章

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读