Red5 0.7 版本的内存泄漏分析和解决方案_JAVA_编程开发_程序员俱乐部

中国优秀的程序员网站程序员频道CXYCLUB技术地图
热搜:
更多>>
 
您所在的位置: 程序员俱乐部 > 编程开发 > JAVA > Red5 0.7 版本的内存泄漏分析和解决方案

Red5 0.7 版本的内存泄漏分析和解决方案

 2010/12/11 11:31:52  tomyz0223  http://tomyz0223.javaeye.com  我要评论(0)
  • 摘要:Red5作为多媒体的开源的框架,实现了RTMP协议,完成了视频,音频和多媒体数据的传输和解析,很多的产品都在使用它。我们同样在用他们的服务,但是遇到一个内存泄漏的问题,这个内存泄漏是如何发现的呢:现象:服务器跑了两天左右,出现了两种情况:1.内存溢出2.内存没有溢出,但是提供不了任何服务,服务器不能接收任何request分析:1.扩大虚拟机的内存,结果服务器跑长了点时间,照样内存溢出2.Dump出Heap快照,并用EclispseMemoryAnalyzer进行分析
  • 标签:解决方案 解决 分析

Red5作为多媒体的开源的框架,实现了RTMP协议,完成了视频,音频和多媒体数据的传输和解析,很多的产品都在使用它。我们同样在用他们的服务,但是遇到一个内存泄漏的问题,这个内存泄漏是如何发现的呢:

?

现象:服务器跑了两天左右,出现了两种情况

1.内存溢出

2.内存没有溢出,但是提供不了任何服务,服务器不能接收任何request

?

分析:

1.扩大虚拟机的内存,结果服务器跑长了点时间,照样内存溢出

2.Dump出Heap快照,并用Eclispse Memory Analyzer进行分析,发现RTMPMinaConnection对象大量存在ConcurrentHashMap对象里面,为什么会出现大量的connnection?即使是大量的客户端请求,为什么内存没有释放?

3.分为三个问题考虑:

1)为什么会出现大量的connnection?连接从哪里来的

2)大量的connection为什么会没有释放?

3)为什么connection达到一定的数量,服务器即使在内存充裕的情况下,仍然提供不了任何服务?

?

根据大量的观测,发现red5 服务器,我们用Haproxy代理了rtmp请求,而HA即使没有请求的情况下,仍然试图连接,以探测代理的服务器是否存活,而red5的keepalive时间一过,会试图关闭连接,关闭之后,通过查看源代码发现,connection虽然关闭了,但是没有从concurrentHashupMap里面remove掉,而真是这种Ha的不停的通过创建心跳连接来探测red5是否处于活的状态,而red5关闭连接之后,并没有从concurrentHashMap里面移除,从而造成了最终的内存溢出,同时由于没有移除inactive的连接达到了red5设定的最大的允许的inactivity连接的数量,默认为60000个连接,从而造成我们刚才看到的现象-即使内存充裕的情况下,仍然提供不了任何服务的情况。

?

查找这个错误的过程是痛苦的,甚至没有一点头绪,还好通过大量的测试和源代码分析,发现了这个问题。我们现在已经升级到red5 0.9.1的版本了,目前情况良好,同时为了确保服务器的稳定性,我们也查阅了相关的源代码,可以确定0.9.1版本中已经fix了这个问题。相信red5 server在我们的产品上线后会处于非常稳定的状态。

?

发现这个问题,一些工具的使用是关键的:

首先,要会分析heap快照,而eclipse memory analyzer确实是很强大的工具。帮我们提供了大量有用的信息。

其次,开源软件是不可靠的,只有我们对它们的代码有深入的分析才会得出好的结果。还好,源代码开放也为我们提供了查找问题来龙去脉的根据。而我们也可以对开源软件进行优化,在以后的内容里,我也会记录我们优化red5 server的整个过程,相信还有很多地方,我们仍然可以优化它。

?

发表评论
用户名: 匿名