跨平台多终端自动播出系统的研究与实现

来源 :传播与制作 | 被引量 : 0次 | 上传用户:shuizhongcanyue
下载到本地 , 更方便阅读
声明 : 本文档内容版权归属内容提供方 , 如果您对本文有版权争议 , 可与客服联系进行内容授权或下架
论文部分内容阅读
  【摘要】 本文探讨了如何实现C/S、B/S架构的自动播出系统,比较两种实现的优缺点,并详细介绍了如何采用HTML5的全新特性WebSocket来实现B/S架构自动播出系统,实现对跨平台、多终端的支持。
  【关键词】 自动播出系统 跨平台 多终端 HTML5 WebSocket
  一. 什么是自动播出系统
  自动控制是指无需人经常直接参与,而是通过对某一对象施加合乎目的的作用,以使其产生所希望的行为或变化的控制[1]。
  广播行业的自动播出系统跟传统的自动控制有所区别,它需要软件和硬件密切配合,才能实现。因为在整个广播播出过程之中,有不同功能的不同类型的设备参与,比如视频服务器、矩阵、主控台等等,而且,这样的设备有可能来源于不同的厂商,如果是完全由人工控制,难度大、不易同步协调,而且安全性得不到保障,自动播出系统的出现使得操作员可以通过一个专门的系统对所有设备进行统一的控制与监视。
  二. C/S自动播出系统的实现
  怎样实现一个广播行业的自动播出系统呢?我们从系统部署、系统架构选择、系统实现三方面来详细分析。
  1. 自动播出系统部署
  一般来说,一个自动播出系统由四部分组成:需要被控制的设备、设备控制服务器、数据库、各种应用客户端,图1说明了它们之间的关系。
  (1)需要被控制的设备
  该部分包括各种需要参与自动播出的设备,比如视频服务器,矩阵,主控台,VTR,字幕机,各种音频卡、视频板等等,它们能够通过网络、或RS422串口、或GPI接口进行控制。
  (2)设备控制服务器
  设备控制服务器是自动播出系统的核心,一般来说设备控制服务器属于两个网络:一个是设备网,设备控制服务器在这个网络上能找到需要控制的所有设备,通过网络协议、RS422串口协议、或者GPI接口发送控制命令到具体设备,从而能够控制设备的运行、监视设备的状态;另一个是应用网,在这个网络上,各种的应用程序能够通过设备控制服务器协议与设备控制服务器进行通讯。为了安全起见、同时避免网络阻塞,设备网与应用网最好保持物理上的独立。
  而且为了保证设备控制服务器的可靠运行,采用主、备的双设备控制服务器是更好的选择。
  (3)数据库
  该数据库包含应用中的各种数据,比如用户信息、业务数据、媒体元数据等等。这些数据既可以给应用提供完善的信息,也可以避免应用频繁操作设备,降低设备的性能,比如媒体元数据。
  (4)各种应用客户端
  该部分包括各种各样的应用,比如播放列表、媒体录入、设备状态监视等等,而且随着需求的变更,应用程序会不停变化或增加。
  2. 软件架构的选择
  通常来说,一个软件有C/S或B/S两种架构可以选择。B/S是Browser/Server,指浏览器和服务器端,在客户机端不用安装专门的软件,只要一个浏览器即可,属于瘦客户端。C/S是Client/Server, 指客户机和服务器,在客户机需要安装客户端软件及相应环境后,才能访问服务器,属于胖客户端。
  表1[2]对B/S和C/S优缺点进行了比较,由于C/S架构的实时性能高且稳定,C/S成了自动播出系统的不二之选。
  3. C/S架构自动播出系统的实现
  在选定了C/S的软件架构后,接下来介绍如何实现自动播出系统的设备控制服务器与客户端。
  (1)设备控制服务器的实现
  要实现设备控制服务器,一般来说包括三层:设备驱动层、事务层、服务层。
  设备驱动层
  这一层包括三部分:设备管理,设备协议,设备驱动。
  设备管理主要用来分类管理各种设备,使得可以很方便得在业务层进行控制。
  设备协议是指对不同类型的设备来说,有不同的控制协议,比如控制视屏服务器的VDCP协议,控制VTR的SONY VTR协议,控制矩阵的矩阵协议等等。
  设备驱动是对某一型号设备的具体支持,它从某一设备协议继承而来,可能受通用协议的控制,但也有自己的一些特性。
  设备驱动层是设备控制服务器的基础,只有在设备驱动层正确地工作的前提下,自动播出系统才有可靠运行的可能。
  事务层
  这一层包括设备控制服务器能够提供的各种事务处理能力,比如播放列表、设备状态监视、媒体服务等。
  播放列表主要用于自动播出,通过维护一个串行的列表,使得节目可以一个接一个得连续自动播出,避免繁琐的操作,减少错误的发生。
  设备状态监视是一个非常重要的部分,这一部分通过对设备状态的监视,预防播出事故,即时通知管理员进行维护与更新,就像汽车的胎压监控仪一样给予安全行驶的保障。
  媒体服务保证设备的媒体信息即时更新,比如视频服务器的媒体信息,并提供方便的方式可以进行媒体录入。更进一步的是,可以提供全局媒体服务,在不同的地方可以共享媒体,快捷方便得进行媒体传输等等。
  服务层
  这一层主要给各种应用客户端提供服务,包括两部分。第一部分是在标准的Socket端口上提供服务,接受来自应用客户端的命令;第二部分是将命令按照自动播出系统的协议将其转换成具体的请求,传递给事务层进行具体的处理。
  图2介绍了服务器端的结构。
  (2)客户端的实现
  客户端的结构相对来说比较简单,但是实现相对繁琐。一般来说客户端包括界面层与控制层。
  界面层
  这一部分看起来比较简单,但根据编程语言的不同,有不同的实现方式,难易程度也不同,比如VC、C#、以及Java就有不同的实现策略。总体来说,这一部分就是提供一个易于操作的界面,使得用户可以方便地控制播放编列、查看设备状态、录入新的媒体等。   控制层
  这一层分为两部分,一部分是将界面事件转换成自动播出系统命令,并将其发送到设备控制服务器;另一部分是数据库部分,提供业务需要的数据,并在恰当的时候进行更新。
  图3介绍了客户端的结构。
  通过上面的介绍,一个C/S架构的自动播出系统构建完毕,它有高的实时性,功能强大,稳定高效,可以用来实现绝大部分的自动播出系统。
  三. 新的挑战以及新的技术
  1. 新的挑战
  但是随时时代的发展、技术的进步,C/S架构的产品受到越来越多的挑战。其中最显著的就是多终端的挑战。从刚开始的PC,到笔记本,再到现在的手机与平板电脑,越来越多的终端要求参与到系统的操作监控过程中,特别是手机与平板,这两个为方便而生的产品。
  这样就要求软件产品在支持个人电脑的同时,也要求能够在手机或平板上运行,这也意味着软件产品需要运行在不同的操作系统上,比如Android, iOS, Windows, Windows Phone等等。对C/S架构的产品来说,这意味着为每一个操作系统的终端,必须开发相应的客户端,从而大大提高了开发的成本以及维护更新的成本。
  2. 新的技术HTML5与WebSocket
  有新的挑战,就有新的技术的出现。HTML5就是这样的一种新技术。HTML5是谷歌、苹果、诺基亚、中国移动等几百家公司一起酝酿的W3C推荐的新一代的网络标准,一个公开的标准。
  HTML5是跨平台的、支持多终端的,因为目前PC、手机、平板上的主流浏览器大都主持HTML5,比如不但苹果的Safari支持HTML5, FireFox, Chrome, Opera等主流浏览器也都支持HTML5,微软的IE9开始支持部分HTML5特性,从IE10开始对HTML5有完善的支持。
  HTML5[3]提出了很多的新特性,比如SVG, Canvas, Gealocation, Web Worker等等,使得开发网络应用简单而且功能强大,很多以前只能通过桌面程序完成的功能也很容易通过HTML5在Web应用中完成。
  在HTML5的众多新特性中,有一个全新的特性WebSocket[4]。
  (1)WebSocket出现的背景
  现在,很多网站为了实现即时通讯,所用的技术都是轮询。 轮询是在特定的时间间隔(如每1秒),由浏览器对服务器发出HTTP request,然后由服务器返回最新的数据给客户端的浏览器。这种传统的模式带来很明显的缺点,即浏览器需要不断的向服务器发出请求,然而HTTP request 的header非常长,里面包含的数据可能只是很少的一部份,这样会占用很多的带宽和服务器资源。
  而比较新的技术去做轮询的效果是Comet,使用了AJAX。这种技术虽然可达到双向通信,但依然需要发出请求,而且在Comet中,普遍采用了长链接,这也会大量消耗服务器带宽和资源。
  面对这种状况,HTML5定义了WebSocket协议,能更好的节省服务器资源和带宽,并达到实时通讯[5]。
  (2)WebSocket的目标与优点
  WebSocket规范的目标是在浏览器中实现和服务器端双向通信[6]。双向通信可以拓展浏览器上的应用类型。这样使得我们可以在利用Web应用的优势的同时,可以使用到Socket高效的点对点通讯方式。
  同时WebSocket服务器与客户端之间交换的标头信息很小,大概只有10字节。而且WebSocket不仅支持纯文本的数据,而且支持二进制的数据通讯。
  (3)WebSocket的原理
  浏览器中的网页与服务器的WebSocket的通讯有两个过程,第一个是握手过程,浏览器发送一个类似于http头的请求给服务器,服务器根据http头中的信息,生成另外一个http头发送个客户端,这样连接就建立了;第二个是通讯过程,每次通讯需要包括WebSocket协议头,根据包长度的不同,从2到10字节不等。
  (4)WebSocket客户端
  WebScoket客户端主要需要浏览器对WebSocket的支持。目前大部分最新版的主流浏览器已经支持WebSocket,比如FireFox,Chrome,Safari等。微软从IE 10也开始支持WebSocket。
  在客户端,很容易用JavaScript来实现,请参考下面的代码:
  当WebSocket初始化时,需要一个网络地址,该地址以ws://或wss://开始,其后是服务器地址或主机名,然后服务端口号。在客户端,可以处理onopen、onmessage、onclose、onerror等事件,从而实现对服务器的回应的处理。当客户端想向服务器发送消息时,只要调用send就可以了。
  (5)WebSocket服务器端
  目前已经有一些Web服务器支持WebSocket,比如Tomcat,node.js等。同时由于WebSocket协议的简单性,用户可以很容易地实现自己的WebSocket服务,提供自己订制的WebSocket通讯服务。
  当用户实现WebSocket服务器段时,主要处理三部分信息:
  握手信息
  在浏览器发送来的http握手请求中,包含key信息,服务器需要根据key信息,按照协议的算法,生成另外一个key,发送给客户端,如果key信息不对,浏览器会拒绝连接。
  WebSocket头信息
  WebSocket头比较简单,包括各种标志位,掩码,以及数据长度等。用户很容易根据WebSocket协议将头信息解析出来。
  定制的通讯协议
  用户根据自己的需求,可以定义自己的数据结构,定制自己的通讯协议。   四. 跨平台多终端自动播出系统的实现
  表1比较了C/S与B/S架构的优缺点,虽然B/S有着众多的优点,由于C/S具有实时性高而且稳定的特点,对自动播出系统来说,只能选择C/S架构。
  但是HTML5的WebSocket的出现使得这个变成可能:自动播出系统既可以保持稳定的高实时性,又可以具有B/S系统的跨平台、支持多终端的优点以及其他众多优点。
  下面就从系统部署、系统实现、系统优点、系统挑战几方面来详细了解新的B/S框架的自动播出系统
  1. 系统部署
  从系统部署的总体架构来看,新的系统同样包括四部分:需要被控制的设备、设备控制服务器、数据库、Web服务器。唯一的变化就是所有应用都将发布于Web服务器上,用户可以通过各种终端的浏览器对应用进行访问。应用与设备控制服务器将通过WebSocket进行通讯,保持以前的点对点的高稳定性以及高实时性。
  图5介绍了B/S自动播出系统的部署图。
  2. 设备控制服务器的实现
  对设备控制服务器来说,与C/S架构的设备控制服务器相比,唯一的变化是将标准的Socket服务替换成WebSocket服务。
  从具体实现来说,就是在客户应用的连接建立以后,服务器与客户端多了一个握手的过程,用来保证通讯的安全,在其后的数据通讯中,数据包多了一个WebSocket协议数据头。其他处理与标准Socket通讯完全相同。
  图6介绍了B/S设备控制服务器的结构。
  3. 应用端的实现
  应用端相比C/S架构的客户端,有很大的不同。首先所有页面发布于Web服务器上,所有的维护更新都是对Web服务器上的内容进行维护更新。客户端不再需要安装任何程序,不再受平台、终端的限制,只要有一个浏览器,就可以实现对系统的访问,从而操作播放列表,查看设备状态,进行媒体录入等。
  一般来说应用端包含三部分:HTML5页面,CSS界面装饰,JavaScript逻辑控制。
  HTML5页面是界面部分,包括应用需要的各种显示信息、控件等等。
  CSS界面装饰决定了HTML5页面怎么样进行显示,而且对不同的终端,由于分辨率的不同,可能需要不同的CSS来对HTML5页面进行装饰。同时可能用到公司的统一CSS库,这样保证公司产品风格的一致性。
  JavaScript逻辑控制是应用端的核心,不但包含了与Web服务器的通讯、数据库的通讯,而且包括与设备控制服务器的WebSocket通讯。当然,在这一部分,可以使用已经存在的通用库,如果jQuery库等使代码变得简单;也可以使用公司的通用函数库,重用公司的已有代码。
  图6介绍了B/S应用端的结构。
  4. 系统的优点
  基于HTML5的WebSocket的B/S自动播出系统具有以下优点:
  (1)像C/S系统一样高效稳定
  从设备控制服务器的实现可以看出,跟C/S架构的自动播出系统一样,它具有高实时性、稳定、功能强大的优点,满足广播播出的需求。
  (2)跨平台与多终端
  新系统可以在不同的平台下使用, 比如Windows, Linux, Andriod, iOS等,这意味着它可以在不同的终端中使用,比如PC, 平板, 手机等。
  (3)易于维护升级
  由于新的应用层发表在Web服务器上,维护升级方便,不需要每个终端进行一一维护升级。
  (4)易于集成扩展
  由于是Web应用,可以很方便得跟已有的业务系统进行集成,或者根据新的需求扩展出新的应用。比如跟已有的广告系统、编单系统、审核系统等进行集成。
  (5)易于重构与重用
  对设备控制服务器来说,只要将标准的Socket服务换成WebSocket服务就可以重构原来的系统。对应用端来说,不管公司的JavaScript函数库,还是CSS的页面装饰库,都可以进行重用。
  (6)分工的明确化
  对于产品设计来说,主要关心页面的功能,也就是HTML5页面内容;对于UI来说,主要关心CSS的装饰效果,而再也不要担心自己设计出漂亮的页面,但是程序员实现不出来;对于程序员来说,只要关心JavaScript的逻辑部分是否正确,从而从烦人的界面渲染中释放出来。
  同时分工的明确化可以提高开发的效率,缩短开发周期,更快地交付客户定制需求等.
  (7)易于公司产品风格的统一
  一般来说,一个公司的产品需要能够保持一样的风格。在新系统中,只要用到公司的通用CSS风格库,就可以保持一致的风格,不需要额外的工作,降低开发的成本。
  5. 系统的挑战
  由于HTML5与WebSocket是新的技术,在开发这样的系统时也面临一些挑战:
  (1)浏览器支持的不确定性
  不同的浏览器对HTML5的支持不尽相同。所以同一个页面在不同的浏览器中可能有不同的表现。这就要求我们在页面的开发过程中,需要考虑到这种差异性,使得产品具有良好的兼容性。
  (2)HTML5的未知性
  HTML5的标准并没有完全的确定,它还在不停的完善中,所以它有着一些不确定因素。据估计,2012年HTML5才会推出建议候选版,并在2022年才会成为W3C推荐标准。这就要求我们要关注标准的变更,使得产品适应标准的变更。
  (3)安全问题
  首先,作为一个网络系统,会遇到到传统的网络安全问题威胁,比如黑客攻击。其次作为一个广播系统,要保证设备的安全性,也就是设备被正确的人监视与控制。所以,当我们开始设计系统时,就要有完善的安全策略以保证系统的安全性。除了一般C/S架构系统的安全措施,如服务器冗余备份、设备网和应用网的物理分离、用户权限管理、历史操作日志以外,针对B/S系统还需要防火墙、VPN等措施,保证远程操作、控制的安全性。
  五. 结束语
  HTML5是发展中的新技术,学习它,应用它,使得您一直走在新技术的前列。 B&P
  缩写词
  参考文献:
  [1] 孙扬声. 自动控制理论. 第三版. 北京: 中国电力出版社, 2004年:第1页
  [2] 鲁春燕,孙 娟. 浅析C/S模式和B/S模式的优缺点. 福建电脑, 2008年, 第6期:第87页
  [3] HTML5 Draft. 2012-03-29. [2012-10-02] http://www.w3.org/TR/html5/.
  [4] The WebSocket protocol draft-hixie-thewebsocketprotocol-76. 2010-05-06.
  [2012-10-02] http://tools.ietf.org/html/draft-hixie-thewebsocketprotocol-76
  [5] WebSocket. 2012-10-21. [2012-11-03] http://zh.wikipedia.org/zh-cn/WebSocket
  [6] WebSocket. 2012-10-24. [2012-11-03] http://baike.baidu.com/view/3623887.htm
其他文献
第二屏的增长是广电行业通过电视节目增强与观众之间信息交流的重要契机  你是否曾经在观看某档电视问答节目时,感叹自己没有上台答题的机会?在观看某档综艺节目时,想要表达自己对于某个参与者的支持?或是查看目前播出节目的相关信息?随着互联网的发展,我们开始在网上聊天室和其他同样感兴趣的人讨论某场比赛的赛况,用微博分享对于春晚、奥运或是某档综艺节目的看法。于是,电视之外的第二屏开始悄然兴起。  据Deloi
期刊
OTT(Over the Top)无疑是最近一段时间视频领域的热点之一,电信运营商希望借OTT促进用户升级带宽,提高ARPU值(Average revenue per user每用户平均收入);电视台或者视频网站希望借OTT开拓付费视频收入,摆脱收入基本靠广告的模式;有线电视网想通过OTT留住现有用户,提升用户使用有线网络的时间;节目商想通过OTT扩大新媒体收入,直接向用户收费,从过去向电视台、视
期刊
【摘要】 广播节目分频播出是当今广播电台扩大听众群体、拓展发展市场所采取的有利运作模式。本文结合湖北音乐广播分频需求,提出了一种低投入、高效率的分频播出系统的设计架构,为整合电台资源、提高节目质量、降低运营成本、扩大优秀节目的覆盖面提供了有效的技术实现方案。  【关键词】 分频播出 主播 分播 转播 自播  一.前言  为有效利用广播现有节目的优势资源,进一步挖掘优秀广播节目的市场价值,不少广播电
期刊
概述  中央电视台2012年伦敦奥运会转播中的采用了实时图文系统,该技术不但大大丰富了奥运赛事转播电视画面和赛事信息,同时也成为大型体育赛事图文资讯信息播出的一次技术实践。该系统是一个高/标清兼容、全网络、全文件化的制播系统,可对图片、文字、视频、音频等数据进行在线整合制作并进行播出。成为了中央电视台2012伦敦奥运会转播中图文制作和播出完整的技术平台。该技术通过中央电视台在2008北京—2012
期刊
【摘要】本文主要通过笔者多年在节目制作中积累下来的经验和心得体会,从音响资料在广播节目制作中的运用、积累保存和在使用中应注意的问题几方面入手进行了阐述,以为广大节目制作人员做好音响资料在广播节目节目制作中尤其是新闻类节目的运用提供参考。  【关键字】音响资料 收集 制作运用 真实音响 效果音响  一.音响资料的概念  “音响资料”是指已经过去的、经过录制、保存的新闻事件或人物的录音素材。如:领袖人
期刊
今年的CCBN,洋铭仍然选择在户外展出,一辆小奔停在广场,它的成果辉煌,已创下5万多公里的业绩;HS-2800已经改版成HD/SD 12通道便携式移动演播室,整机小于9公斤,符合航空携带标准,可手提上飞机,即可以用于电视台现场制作,也可以用于教学演示,360度操作,方便了解内部结构;NVS-20网络直播编码服务器,只要输入高标清音视频信号,再将网络接到Hub,可供Mac、PC或Android平台接
期刊
IT和电信频频“插足”视频领域,打破了以前广电舒适的生活现状。很简单的事实正在发生,例如,我身边许多曾经是IT界的朋友开始涉足广电视频市场。他们说“我以前的工作主要集中在IT领域,但现在我正热衷于帮助公司打入广电视频领域。”  电视俨然已经成为“肥肉”一块,涉及电视业务的各类企业正向大视频产业链集结,竞争水深火热。与此同时,这一竞争又聚焦于拥有开放特质的OTT TV。随着光纤网络、云技术、物联网、
期刊
2012年是Ka波段卫星宽带通信蓬勃发展的一年。随着三颗高容量(70-140Gb/s)Ka波段宽带通信卫星Eutelsat Ka-Sat 9A、Viasat 1和EchoStar 17全面投入商业运行,欧洲知名的卫星运营商Eutelsat通信公司、美国两大卫星宽带服务提供商ViaSat有限公司和休斯网络系统公司,在为欧美地区的消费者推出新Ka波段高速卫星宽带互联网服务的同时,也透过其高性能的Ka-
期刊
海南地球站上行系统综合述评  符平白  海南省广播电视卫星地球站  【摘要】 本文阐述了海南地球站上行系统的具体配置,对上行链路进行了全面的综合分析及评论,总结归纳出某些上行设备运行以来出现的典型事例以示借鉴。  【关键词】 上行系统?上行链路?上行设备?压缩编码?复用?调制  上行系统是地球站最主要的技术系统,其功能是对上行信号进行编码、复用、调制和变频等处理,最后经高功放对信号放大后送给上行天
期刊
【摘要】 随着模拟电视向数字电视的过渡,不同电视频道间伴音响度差异大的问题引起了全球范围内的广泛关注。本文针对各个电视频道响度差异大的问题,在制作、播出、传输、分配和接收各个环节进行调查、测试和分析,探究响度差异的产生原因。  【关键词】 响度控制 响度差异分析  一.背景  随着模拟电视向数字电视的过渡,不同电视频道间伴音响度差异大的问题引起了全球范围的广泛关注。在我国有线数字电视向数字化转移的
期刊