`
Poechant
  • 浏览: 229485 次
博客专栏
Bebe66e7-3a30-3fc9-aeea-cfa3b474b591
Nginx高性能Web服务...
浏览量:24321
5738817b-23a1-3a32-86de-632d7da73b1e
Cumulus实时媒体服务...
浏览量:22101
社区版块
存档分类
最新评论

OpenRTMFP/Cumulus Primer(21)经由服务器的发布/订阅流程的关键点

 
阅读更多

OpenRTMFP/Cumulus Primer(21)经由服务器的发布/订阅流程的关键点

  • 作者:柳大·Poechant(钟超 Michael)
  • 博客:Blog.csdn.net/poechant
  • 邮箱:zhongchao.ustc@gmail.com
  • 日期:July 23th, 2012

整个流程概括如下:

Flash 客户端通过 NetConnection 与 Cumulus 建立连接,然后通过 NetStream 使用 RTMFP 发布 Audio/Video/Data(下面简称为 A/V/D) 给服务器,这个 Flash Player 就作为一个发布者(Publisher)。RTMFP 服务器接收到后给所有的订阅者(Subscribers)发送 Audio/Video/Data。

1 客户端发布(Publishing on client side)

通过 NetConnection 连接 RTMFP 服务器 Cumulus,可以参考《OpenRTMFP/Cumulus Primer(2)用Lua编写HelloWorld应用扩展CumulusServer》一文。关键的一个语句如下,其中 nc 是一个 NetConnection 对象(不是“脑残”的意思 - -|||):

nc.connect("rtmfp://localhost:1935");

在连接成功后通过 NetStream 发布 Audio/Video,如下所示,其中 ns1 是一个 NetStream 对象。

ns1.publish("poechant_media_flow", "live");

根据音视频不同的需求,播放相应内容。如果是发布 Data,则使用NetStream.send()来实现。这样就完成了客户端的 A/V/D 发布

2 服务器端(Server-side)

Cumulus 通过 RTMFPReceiving 这个 RTMFP 协议数据接收引擎完成一些连接建立的相关动作,以及接收数据包:

void RTMFPServer::receive(RTMFPReceiving& rtmfpReceiving);

该函数会在收到客户端发来请求时响应,如果是仍未建立连接的请求,则由此创建 Session(RTMFP 的核心概念之一),并取出其中的数据包。这其中有多个过程,我这里就不详述,以后会发布文章来解释。

继续我们的话题,在RTMFPServer::receive 函数中如果是建立连接阶段,则会调用 Handshake 类的 receive 来做接下来的处理,这个我就不去详细分析了,因为与本文主题无关。与本文有关的是,如果是已经创建了 Session 的,则会调用:

void ServerSession::packetHandler(PacketReader& packet);

这是一个相对复杂的函数,会从 packet 中取出很多有用的信息。此外,比较重要的是,在我们上述情况下,会调用 Flow 类的:

void Flow::fragmentSortedHandler(UInt64 stage,PacketReader& fragment,UInt8 flags);

该函数中会对 Audio/Video/Data 分别响应不同的处理机制:

switch(type) {
    case Message::AMF_WITH_HANDLER:
    case Message::AMF:
        messageHandler(name,amf);
        break;
    case Message::AUDIO:
        audioHandler(*pMessage);
        break;
    case Message::VIDEO:
        videoHandler(*pMessage);
        break;
    default:
        rawHandler(type,*pMessage);
}

接下来在 Publication 中完成对所有订阅了该发布者的 Flash Players 发送信息,核心的代码为:

for(it=_listeners.begin();it!=_listeners.end();++it) {
    it->second->pushAudioPacket(time,packet);
    packet.reset(pos);
}

for(it=_listeners.begin();it!=_listeners.end();++it) {
    it->second->pushVideoPacket(time,packet);
    packet.reset(pos);
}

for(it=_listeners.begin();it!=_listeners.end();++it) {
    it->second->pushDataPacket(name,packet);
    packet.reset(pos);
}

其中的 _listeners 就是该 Publication 中的所有订阅者。订阅者的添加/删除是通过:

Listener& addListener(
    Peer& peer,
    Poco::UInt32 id,
    FlowWriter& writer,
    bool unbuffered);

void removeListener(
    Peer& peer,
    Poco::UInt32 id);

这两个函数来实现的。

要注意的是,在 Publication 中已经完成了向订阅者发布信息,之后虽然会响应到 Peer 及 RTMFPServer 的onAudioPacketonVideoPacketonDataPacket,但此时都与订阅者接收信息无关了。Cumulus 正是在RTMFPServer::onAudioPacketRTMFPServer::onVideoPacketRTMFPServer::onDataPacket中调用用户定制的服务(Lua 脚本实现),完成一些自定义的需求。我是在此通过直接的 C++ 功能扩展,来添加业务需求的,没有使用 Lua 脚本及 Cumulus 中的 Lua 脚本引擎,主要原因是为了提高效率。

3 客户端订阅(Subscribing on client side)

订阅很简单,在play的时候传入正确的发布者名称即可。

ns2.play("poechant_media_flow");

测试代码可以参考 Reference-1,其中的例子是关于NetStream::send(…)的,用于发送 Data,Audio 和 Video 的程序可以参考该例修改。

客户端订阅后,这些信息并不会直接从发布者那里通过 P2P 的方式接收。如果想使用发布者与接受者直接连接的方式,则需要在 NetStream 初始化的时候,传入NetStream.DIRECT_CONNECTIONS参数,默认的NetStream.CONNECT_TO_FMS是将数据上行到服务器再下行给所有订阅者(Subscribers)的。根据不同的应用场景,可以使用不同的方式。

4 Reference

  1. http://help.adobe.com/en_US/FlashPlatform/reference/actionscript/3/flash/net/NetStream.html#send()

-

转载请注明来自柳大的CSDN博客:Blog.csdn.net/poechant

-

分享到:
评论

相关推荐

    OpenRTMFP Cumulus Primer()入门介绍与部署CumulusServer.pdf

    《OpenRTMFP Cumulus Primer 入门与CumulusServer部署》 OpenRTMFP (Real Time Media Flow Protocol) 是一种技术,它为Flash实时应用提供了高并发扩展能力。OpenRTMFP/Cumulus是基于GNU General Public License的...

    cumulus-linux-4.4.0-vx-amd64-qemu.zip

    在Cumulus Linux 4.4.0中,用户可以期待以下关键特性: 1. **网络操作系统(NOS)**:Cumulus Linux提供了一个专门的网络操作系统,它支持标准的Linux命令行界面和开发工具,同时包含了网络特定的功能,如路由协议...

    Flex P2P 音视频流客户端(Cumulus支持)

    Flex P2P 音视频流客户端是基于Adobe Flex...对于开发者来说,了解并熟练掌握Cumulus和OpenRTMFP是构建此类应用的关键。同时,"flashyy-protocwrapper"这样的工具则能帮助开发者更高效地处理协议消息,优化整体性能。

    RTMFP服务器脚本CumulusServer.zip

    openrtmfp又名Cumulus Server是一个完全开源和跨平台的可扩展的RTMFP服务器脚本。Cumulus Server在GPL 框架下遵循速度、优势、跨平台、轻量和高质量代码。Cumulus Server的每一个版本都是通过严格测试和审核的。可...

    cumulus(浑天仪)使用手册

    《浑天仪(Cumulus)使用手册》是一个详细介绍如何使用Cumulus这一开源工具的文档,主要面向对源码和工具感兴趣的IT从业者。Cumulus可能是基于Web的项目管理工具或者数据分析平台,而`swfobject.js`和`tagcloud.swf`...

    wp-cumulus(支持中文标签)

    **wp-cumulus插件详解** `wp-cumulus`是一款专门为WordPress博客设计的炫酷三维标签云插件。这款插件以其独特的视觉效果和良好的用户体验,在众多的WordPress标签云插件中脱颖而出。通过使用`wp-cumulus`,用户可以...

    HPCCloud:基于 CloudWeb 的仿真环境

    高性能计算云 目标 ...$ vi /opt/hpccloud/cumulus/cumulus/conf/config.json +- > Fix host to be localhost +- > baseUrl: " http://localhost:8080/api/v1 " , $ sudo service celeryd restar

    Cumulus官网视频会议样例代码

    这里给出了cumulus/OpenRTMFP的git官网提到的视频会话样例的AS3代码,包括服务器端和客户端两部分,我已经在<使用Cumulus和Flash Player搭建视频会议示例>http://blog.csdn.net/tao_627/article/details/18041473中给...

    Cumulus:一个基于网络编码的分布式文件系统.pdf

    4. **系统架构与实现**:Cumulus 修改了Hadoop的源代码,以支持网络编码的存储和检索流程。这包括对NameNode和DataNode的角色重新定义,以及对Block和BlockReplica的概念进行扩展,以适应编码块的管理。 5. **性能...

    cumulus-linux-cookbook:用于管理积云开关的手册

    这本食谱在 vanilla Debian 上创建了一个交换机覆盖,并且还部署在 Cumulus 路由器/交换机上。 要求 测试 访问 Debian Wheezy 盒子 生产 访问 Cumulus HCL [1] 开关(Accton AS6701_32X,这就是这本食谱最初的目的)...

    wp-cumulus

    "wp-cumulus" 插件的一些关键特性包括: 1. **3D立体效果**:标签以立体形式呈现,用户可以观察到每个标签的旋转和上升下降,增强视觉吸引力。 2. **自定义设置**:你可以调整标签的字体、颜色、大小、速度以及云的...

    wp-cumulus_3D云标签

    《WordPress中的wp-cumulus 3D云标签详解》 在WordPress这个强大的开源博客平台中,wp-cumulus是一款极具特色的3D云标签插件。它以其独特的视觉效果和交互体验,为用户提供了全新的标签展示方式,使得博客的分类和...

    cumulus:Cumulus框架+ Cumulus API

    积云框架 :open_book: 文献资料 最新文档。 文档。 更多信息 有关此项目的更多信息,以及有关NASA的地球观测系统数据和信息系统(EOSDIS)及其云工作的更多信息,请联系或访问 。...这是用于Cumulus开

    Cumulus:CloudApp 的开源替代品,利用您自己的 S3 进行存储

    积云Cumulus 是的免费、开源替代品,它利用您自己的 S3 进行存储。下载您可以在下载最新版本更改默认截图目录这是可选的。 默认情况下,OS X 会将屏幕截图放在您的桌面上。 但是,如果您希望他们去其他地方,您可以...

    3D标签云单机中文版 WP-CUMULUS 1.23

    大名鼎鼎的WP-CUMULUS 3D标签云,已经改成支持中文标签,可在.htm自行添加标签链接,可以单机玩耍测试,不需要安装WordPress然后装插件~~ 主要是有些童鞋只是想要3D标签云动画,所以就提取重要文件出来稍作修改下.

    cumulus-integration-tests:Cumulus工作流的集成测试[已弃用]

    Cumulus集成测试项目[已弃用] 注意:此存储库不再维护。 该存储库的内容已移至。 什么是积云? Cumulus是NASA未来地球科学数据流的基于云的数据提取,存档,分发和管理原型。 阅读 安装 nvm use npm install 在...

    Mellanox Cumulus 培训资源

    Mellanox Cumulus学习,基本使用,培训资源

    wp-cumulus.rar_TagCloud._TagCloud.as_flex cumul_wp cumulus_wp cu

    【标题】"wp-cumulus.rar" 是一个与WordPress相关的压缩包,其中包含"TagCloud._TagCloud.as",这表明它与创建和展示WordPress标签云的插件有关。"flex cumul_wp cumulus_wp cu"暗示这个插件可能是用Adobe Flex技术...

    docs:Cumulus Networks文档库

    安装文档并运行本地服务器 Hugo包含一个本地开发服务器,用于构建和查看仓库的实时更改。 要构建和查看实时站点: 从扩展安装Hugo 0.65.3版本。 用hugo version验证雨果。 该站点支持Hugo 0.65.3版。 hugo version...

    Python库 | cumulus-1.1.0.tar.gz

    此外,“后端”标签暗示cumulus库可能更侧重于服务器端的操作,而非前端用户界面。 总结起来,cumulus-1.1.0是一个Python库,可能是用于处理云计算相关任务或数据处理的工具。它的安装和使用涉及基本的Python包管理...

Global site tag (gtag.js) - Google Analytics