`
wang5598
  • 浏览: 112885 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

Red5边源服务器集群部署

    博客分类:
  • Red5
阅读更多

Red5边源服务器集群部署

WYQ 

1.     Red5简介

      Red5是一个采用Java开发开源的Flash流媒体服务器。它支持:把音频(MP3)和视频(FLV)转换成播放流; 录制客户端播放流(只支持FLV);共享对象;现场直播流发布;远程调用。Red5使用RTMP作为流媒体传输协议,在其自带的一些示例中演示了在线录制,flash流媒体播放,在线聊天,视频会议等一些基本功能。

 

Red5是建立在Jetty(servlet engine) Mina (networking)基础之上的,并通过使用Spring框架将起整合起来的。Jetty是一款运行速度较快轻量级的开源servlet 容器,可以作为嵌入式服务使用。Mina Apache组织下的一个基于 Java NIO 技术的新项目,它为开发高性能和高可用性的网络应用程序提供了非常便利的框架。Spring是轻量级Java企业级开发的事实标准,Red5采用Spring来管理使程序逻辑更加清晰,耦合性更低,扩展性更好。

 

2.   Red5与在线教室(Openmeetings项目的二次开发)的关系:

    在线教室是以Red5为视频流媒体服务器,通过Red5实现视频、音频、白板数据等实时发布和录制、通过RTMP协议实现对JAVA方法的远程调用,并提供在线聊天等服务。在整个系统中,Red5服务器起到了基石的作用,在Red5基础上开发我们自己的功能以提供学生教师在线上课的所有需求。

 

3.   Red5的集群:   

    OnlineClassroom开发采用的技术是:前端采用openlaszlo开发的flash客户端,后端采用Red5服务器,因为前端和后台之间采用RTMP(Realtime messaging protocol)进行连接,除非前端使用退出或者关闭功能,否则该连接会一直持续,我们知道,打开一个连接是要耗费系统资源的,当连接数众多时,会使服务器不堪重负,无法提供有效响应速度,所以需要多台服务器来分流用户连接;采用边源服务器的模式,边服务器(Edge Server)用来接受来自于客户端的连接,并将多个相同用户域的连接进行合并进行多路复用,统一转发给源服务器(Origin Server)进行处理,在源服务器处理完数据后再转发给边服务器,再由边服务器转发给客户端用户。这样做的好处是可以提高系统的承载能力。

 

4.   部署步骤说明: 

Red5官方网站目前有提供关于集群的指导文档,地址是:http://trac.red5.org/wiki/Documentation/Tutorials/EdgeOriginClusteringConfiguration 需要说明的是,官方文档提供的步骤过于简略,实际执行过程中会碰到诸多错误,所以整理以下的操作步骤,以供参考:

 

 Red5的下载地址是:http://trac.red5.org/downloads/0_8/red5-0.8.0-java5.tar.gz

 安装目录是 /var/www/html/red5 (版本为0.8.0.0)

 Tar –xzvf red5-0.8.0.tar.gz –C /var/www/html/red5

 

以上配置针对的是Red5 (版本0.8.0.0),下载地址是:http://trac.red5.org/downloads/0_8/red5-0.8.0-java5.tar.gz

其它版本(0.91.0)经过测试,均无法实现集群效果。附上所有配置文件和需要的JAR包,以供下载。

 

二、注意:

在使用边源模式的时候,flash会经过边服务器去访问源服务器上的资源,这时候会涉及到flash的安全性和跨域访问数据的问题,这时需要在源服务器的Red5的安装目录下的webapp/root下面修改crossdomain.xml文件,添加:<allow-access-from domain="* " to-ports="20-65535"/>。此步骤十分必要,否则项目会出现资源禁止访问的错误。

 

 

三、源服务器的配置(需要首先安装Javared5,然后在安装openmeetings以及对应的插件,详细安装过程请看“在线教室插件安装说明.docx”):

 l  1.导入2jar包到red5lib目录下面。(分别是:mina-integration-spring-1.1.7.jar mina-filter-ssl-1.1.7.jar

l 2.删除red5lib目录下面的antlr-3.1.2.jar升级到antlr-3.1.3.jar

l  3.将“源服务器配置文件.zip”中的3xml文件解压到red5/conf下面。

l  4.确保源服务器上的9035端口没有被防火墙禁用。

l  5.部署应用项目(在线教室即openmeetings)到webapp下面,然后启动red5.sh

 

 

 

四、边服务器的配置(需要首先安装Javared5): 

l1.导入2jar包到red5lib目录下面(分别是:mina-integration-spring-1.1.7.jar mina-filter-ssl-1.1.7.jar

l2.删除red5lib目录下面的antlr-3.1.2.jar升级到antlr-3.1.3.jar

l3.源服务器中red5/webapp/openmeetings/WEB-INF/lib目录,将openmeetings.jarhibernate3.jar拷贝到边服务器的res5/lib目录下面(仅此2jar包,不要拷多了,不然会引起报错的)。

l4.将“边服务器配置文件.zip”中的3xml文件解压到red5/conf目录下面。

l5.更新red5/conf/red5-edge-core.xml 的配置文件,修改 "mrtmpClient" 中的server属性,使其指向源服务器的IP地址。

l6启动red5主目录下的red5.sh脚本。

l7.补充一点,在边服务器在设置好开机自启动脚本,这样每次由边服务器管理功能所新增的边服务器都能自动运行red5的脚本,避免手动执行的麻烦。脚本如下:

 

vi /etc/rc.d/rc.local 在文件最后一行添加如下命令:

cd /var/www/html/red5

./red5.sh

然后保存退出。

 

五、flash服务器的配置(需要首先安装JDK1.6):   

l1.经过测试,可以把flash服务器部署在windows的虚拟机上都可以。这样方便管理。

l2.安装openlaszlo,目前版本为4.9.0,在附件中已经提供了windows下的安装包,一路点击Next.我这里安装路径是:C:\Program Files\OpenLaszlo Server 4.9.0;然后将在线教室的客户端程序放到Server\lps-4.9.0目录下:全路径如:C:\Program Files\OpenLaszlo Server 4.9.0\Server\lps-4.9.0\onlineroom

l3.更新config.xml文件,将rtmphostlocal指向默认的边服务器的IP,将red5ogigin指向源服务器对应的IP,将red5flash指向flash服务器的IP,如果支持边源模式将supportcluster的值设为true,否则设置为false将附件中index.html文件替换到C:\Program Files\OpenLaszlo Server 4.9.0\Server\tomcat-5.0.24\webapps\ROOT下面。(顶替原文件即可)。

l4.安装完成以后,启动openlaszlo。所有安装即完成。

 

然后启动浏览器输入地址:如http://172.10.106.166:8080

分享到:
评论
4 楼 gtb6900 2013-06-30  
当flv文件超过10M后集群无法运行,报错:
2013-06-30 17:25:59,875 [pool-3-thread-1] ERROR org.red5.io.flv.impl.FLVReader - New position exceeds limit
2013-06-30 17:25:59,875 [pool-3-thread-1] ERROR o.r.s.m.InMemoryPullPullPipe - exception when pulling message from provider
java.lang.RuntimeException: New position exceeds limit

貌似有什么限制?
我QQ:479880729
3 楼 LJG0510 2012-08-17  
太给力了   找了好久 都没找到这么好的 文章        
2 楼 mbguest 2012-05-23  
感谢提供配置和jar包
1 楼 5681 2011-12-30  

相关推荐

    red5集群cluster方案

    Red5集群解决方案旨在创建一个由origin(源服务器)和edge(边缘服务器)组成的系统,origin负责处理媒体内容的发布和存储,而edge则负责向客户端分发内容,减轻origin的压力。 2. **origin服务器集群方案** - **...

    red5集群配置文件edge

    "red5集群配置文件edge"指的是在Red5 1.0版本中,针对集群环境的边缘服务器(Edge Server)的配置文件。Edge Server是集群架构中的重要组成部分,负责分发和缓存来自源服务器的内容,减轻源服务器的压力。 在配置...

    Red5用户参考手册-中文版

    总之,Red5用户参考手册是入门者和专业人士获取Red5知识的重要资源,它覆盖了Red5的安装、配置、应用、安全、集群、管理等方方面面,帮助用户深入理解Red5的架构和使用方法,从而有效地部署和管理Red5流媒体服务器。

    CDH软硬件配置建议

    网络拓扑方面,CDH推荐的集群部署可以是单机架或多机架配置。单机架配置适合小规模集群,而多机架配置有利于大型集群的扩展和容错性提升。 根据上述知识点,可以得知CDH部署时需考虑的软硬件配置要素非常全面。合理...

    国产服务器操作系统发展报告(2023年).pdf

    全球服务器操作系统市场上,微软Windows Server、Red Hat Enterprise Linux (RHEL)、SUSE Linux Enterprise Server (SLES)等占据了主导地位。这些系统凭借强大的生态支持、丰富的功能以及广泛的应用案例,赢得了市场...

    安装k8s和kubeedge手动下载的一些文件

    - **EdgeCore**:部署在边缘设备上,包括 edged(边缘节点代理)、edgeservice(边缘服务管理)、mqttbroker(消息代理)等组件。 2. **边缘节点注册**:使用 `kubeadm join` 或 KubeEdge 提供的 `cloudcore` 工具...

    wildfly-dev-cookbook:WildFly 开发手册

    WildFly,前身为JBoss AS,是Red Hat公司推出的开源应用服务器,它提供了丰富的功能来支持企业级Java应用程序的部署和管理。 一、WildFly介绍 WildFly是基于Java EE规范的应用服务器,它实现了Java EE的各个版本,...

    JAVA上百实例源码以及开源项目源代码

    Java数组倒置 简单 Java图片加水印,支持旋转和透明度设置 摘要:Java源码,文件操作,图片水印 util实现Java图片水印添加功能,有添加图片水印和文字水印,可以设置水印位置,透明度、设置对线段锯齿状边缘处理、水印...

    kourier:Kourier是Knative服务入口。 它已经被Knative采纳,我们将继续在github.comknativenet-kourier上进行开发。

    Kourier是这个领域的一个重要实现,它将Kubernetes的Ingress概念与Serverless理念相结合,为Knative服务提供了强大的边缘服务功能。 OpenShift是Red Hat提供的一个企业级Kubernetes平台,它增强了Kubernetes的安全...

Global site tag (gtag.js) - Google Analytics