博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
openfire BOSH 内存泄露
阅读量:6070 次
发布时间:2019-06-20

本文共 726 字,大约阅读时间需要 2 分钟。

hot3.png

   在解决openfire BOSH的一个bug中,偶然发现openfire BOSH有内存泄露的情况。

   先提供一个jmap命令来跟踪内存泄露:

jmap -histo:live $OPID | grep HttpSession

   $OPID是openfire的进程号。 HttpSession是openfire BOSH重要的数据结构和逻辑处理模块。

   这里不介绍openfire BOSH的具体逻辑。只会简单的说明一下几个对象之间的关系:

   1) 当一个client连接到openfire BOSH接口后,就会有一个HttpSession来负责处理所有和这个client之间的消息交互。

   2) 一个HttpSession包含一个HttpConnection队列。client和server之间的每一个交互对应一个HttpConnection。

   3)server维护了一个全局的map来保存所有的HttpSession。

   当client因为某种原因断开和BOSH的连接,发现和这个client相关的HttpConnection/HttpSession并没有被释放。

   原因是什么那?

   最直接的原因是当HttpSession中断后,server并没有把这个session从map删除掉。

   为什么没有被删除掉?

   原因是server在清理这个HttpSession之前,抛异常了,导致清理Session工作没有被执行。

   所以我们要catch住这个异常,让server正常的清理session。

   具体的方法是在HttpSession中的closeConnection()方法。

   

 

转载于:https://my.oschina.net/u/145002/blog/75879

你可能感兴趣的文章
Linux服务器性能评估与优化
查看>>
ListView 详解
查看>>
初窥系统集成
查看>>
程序员应该知道的100个Vim命令
查看>>
实验设计与排错之一静态路由
查看>>
第二篇:JAVA字符编码系列二:Unicode,ISO-8859-1,GBK,UTF-8编码及...
查看>>
如何应对勒索病毒
查看>>
Servlet系列文章(一)
查看>>
点击文件下载
查看>>
纯java环境下sqlsqlcipher解密sqlite数据库文件
查看>>
思科路由器基本命令学习总结
查看>>
Mysql 5.7.9源代码安装
查看>>
【表单设计】input的size和maxlength属性
查看>>
存储方案与存储产品之DAS篇
查看>>
Solr1.3的核心机制
查看>>
vue 按需加载
查看>>
OpenCV编程->ROI区域保存为图片
查看>>
SS哥的crontab教程
查看>>
python 面向对象
查看>>
兼职议会
查看>>