http://www.myexception.cn/open-source/446184.html

  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.9和1.0)经过测试,均无法实现集群效果。附上所有配置文件和需要的JAR包,以供下载。

二、注意:

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

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

l  1.导入2个jar包到red5的lib目录下面。(分别是:mina-integration-spring-1.1.7.jar 和 mina-filter-ssl-1.1.7.jar)

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

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

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

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

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

l1.导入2个jar包到red5的lib目录下面(分别是:mina-integration-spring-1.1.7.jar 和 mina-filter-ssl-1.1.7.jar)

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

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

l4.将“边服务器配置文件.zip”中的3个xml文件解压到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

1 楼 5681 2011-12-30  
 
2 楼 mbguest 2012-05-23  
感谢提供配置和jar包

Red5边源服务器集群部署的更多相关文章

  1. FastDFS集群部署

    之前介绍过关于FastDFS单机部署,详见博文:FastDFS+Nginx(单点部署)事例 下面来玩下FastDFS集群部署,实现高可用(HA) 服务器规划: 跟踪服务器1[主机](Tracker S ...

  2. FastDFS集群部署(转载 写的比较好)

    FastDFS集群部署   之前介绍过关于FastDFS单机部署,详见博文:FastDFS+Nginx(单点部署)事例 下面来玩下FastDFS集群部署,实现高可用(HA) 服务器规划: 跟踪服务器1 ...

  3. Fastdfs集群部署以及基本操作

    FastDFS引言 本地存储与分布式文件系统 本地存储的缺点: 是否有备份? 没有 成本角度? 贵 ​ 服务器 :用于计算 ---- cpu/内存 ​ 用于存储 ---- 硬盘大 存储瓶颈? 容量有限 ...

  4. Quartz.net持久化与集群部署开发详解

    序言 我前边有几篇文章有介绍过quartz的基本使用语法与类库.但是他的执行计划都是被写在本地的xml文件中.无法做集群部署,我让它看起来脆弱不堪,那是我的罪过. 但是quart.net是经过许多大项 ...

  5. Openfire 集群部署和负载均衡方案

    Openfire 集群部署和负载均衡方案 一.   概述 Openfire是在即时通讯中广泛使用的XMPP协议通讯服务器,本方案采用Openfire的Hazelcast插件进行集群部署,采用Hapro ...

  6. 基于Tomcat的Solr3.5集群部署

    基于Tomcat的Solr3.5集群部署 一.准备工作 1.1 保证SOLR库文件版本相同 保证SOLR的lib文件版本,slf4j-log4j12-1.6.1.jar slf4j-jdk14-1.6 ...

  7. jstorm集群部署

    jstorm集群部署下载 Install JStorm Take jstorm-0.9.6.zip as an example unzip jstorm-0.9.6.1.zip vi ~/.bashr ...

  8. CAS 集群部署session共享配置

    背景 前段时间,项目计划搞独立的登录鉴权中心,由于单独开发一套稳定的登录.鉴权代码,工作量大,最终的方案是对开源鉴权中心CAS(Central Authentication Service)作适配修改 ...

  9. Windows下ELK环境搭建(单机多节点集群部署)

    1.背景 日志主要包括系统日志.应用程序日志和安全日志.系统运维和开发人员可以通过日志了解服务器软硬件信息.检查配置过程中的错误及错误发生的原因.经常分析日志可以了解服务器的负荷,性能安全性,从而及时 ...

随机推荐

  1. IOSSelector的用法

    1.首先,@selector 里面的方法不能传参数..不要相信网上的..都是复制粘贴的.2.分三步走:1.设置tag.2.设置btn的调用方法.3.使用参数2.看示例代码把..   UIButton ...

  2. apk反编译(1)用apktool破解apk

    1,下载 http://ibotpeaches.github.io/Apktool/ 2,破解 把下载的apktool_2.0.3.jar 和 weixin638android680.apk  拷贝到 ...

  3. Android列表视图(List View)

    Android列表视图(ListView) ListView是一个显示滚动项列表的示视图组(viewgroup),通过使用适配器(Adapter)把这些列表项自动插入到列表中.适配器比如从一个数组或是 ...

  4. .net 程序员成长路线图?

    https://www.zhihu.com/question/25474641 得看赵四本, @赵劼 推荐的. CLR via C# .net Essentials C# in Depth Frame ...

  5. Effective C++学习笔记 条款04:确定对象被使用前已先被初始化

    一.为内置类型对象进行手工初始化,因为C++不保证初始化它们. 二.对象初始化数据成员是在进入构造函数用户编写代码前完成,要想对数据成员指定初始化值,那就必须使用初始化列表. class A { pu ...

  6. js 中 typeof 的使用

    js中的变量是松散类型(即弱类型)的,可以用来保存任何类型的数据. typeof 可以用来检测给定变量的数据类型,可能的返回值: 'undefined' --- 这个值未定义 'boolean' -- ...

  7. Redis cluster学习 & Redis常识 & sort操作

    Redis中的5种数据类型String.Hash.List.Set.Sorted Set. Redis源码总代码一万多行. 这篇文章有一些Redis "常识" http://www ...

  8. Unique Encryption Keys (思维题 预处理)

    题目 题意:给m个数字, q次询问, 询问b到e之间如果有重复数字就输出, 没有就输出OK 思路:用f[i]数组 记录从i开始向后最近的有重复数字的 位置, 如 1 3 2 2, 则f[1] = 4; ...

  9. uvalive 3523 Knights of the Round Table 圆桌骑士(强连通+二分图)

    题目真心分析不出来.看了白书才明白,不过有点绕脑. 容易想到,把题目给的不相邻的关系,利用矩阵,反过来建图.既然是全部可行的关系,那么就应该能画出含奇数个点的环.求环即是求双连通分量:找出所有的双连通 ...

  10. None

    0 值的整型 / 浮点型.空字符串('').空列表([]). 空元组((,)).空字典({}).空集合(set())都等价于 False,但是不等于 None thing = None if thin ...