记录DWR所致的内存泄漏

本文记录了一次由于DWR导致的内存泄漏问题。在分析9G的堆转储文件后,发现DWR的comet模式导致了内存无法释放。通过研究DWR的工作模式,发现长连接在页面刷新或关闭时未正确断开,引发内存泄漏。解决方案是引入DWR3.0版本的监听器来销毁无效session,同时关注官方更新修复的BUG,以进一步解决线上问题。
摘要由CSDN通过智能技术生成

前言

很幸运的从线上传回了即将宕机的服务器的堆转储文件
通过jdk自带工具jmap
jmap -dump:live,format=b,file=X://filepath//heap.bin pid
dump文件高达9G,还好7Z的压缩率很高,压缩到600M,发回给我进行分析。
在这里插入图片描述
在这里插入图片描述
初次打开这个文件就用了将近二十分钟,分配了8G内存。。
在这里插入图片描述
在这里插入图片描述

发现问题

在这里插入图片描述
显然,DWR这个类,是内存泄漏的关键问题,占用内存高达4G,是总占用内存的96.3%
于是我打开百度,开始漫无目的的找资料,我本身是写后端或者算法的,对这种前端框架不太懂。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值