视频直播CDN技术实现方案_第1页
视频直播CDN技术实现方案_第2页
视频直播CDN技术实现方案_第3页
视频直播CDN技术实现方案_第4页
视频直播CDN技术实现方案_第5页
已阅读5页,还剩8页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、(Si白吧视频直播CDN技术实现方案一起扫个盲通常我们所说的视频,是指连续的图象变化每秒超过24帧(Frame )画面以上时,根据视觉暂留原理,人眼无法辨别单幅的静态画面,看上去是平滑连续的视觉效果,这样连续的画面叫做视频。其中内容分发网络就是大家常说的CDN ,这里主要包含流媒体服务器,负载均衡,路由重定向,视频转码,视频录制存储,防盗链,性能等相关技术内容。I白鸽学HECDH.CDFCBNuser卜面这几个词我们也经常遇到码率是数据传输时单位时间传送的数据位数,一般我们用的单位是 kbps即千位每秒。通俗一点的理解就是取样率, 单位时间内取样率越大,精度就越高,处理出来的文件就越接近原始文

2、件,但是文件体积与取样率是成正比的,所以几乎所有的编码格式重视的都是如何用最低的码率达到最少的失真。但是因为编码算法不一样,所以也不能用码率来统一衡量音质或者画质。另一个常见的词是帧,它是一段数据的组合,它是数据传输的基本单位。就是影像动画中最小单位的单幅影像画面,相当于电影胶片上的每一格镜头。一帧就是一副静止的画面,连续的帧就形成动画,如电视图 像等。 与之相对应的帧率,即每秒显示帧数,帧率表示图形处理器处理场时每秒钟能够更新的次数。高的帧率可以得到更流畅、更逼真的动画。一般来说30fps就是可以接受的,但是将性能提升至60fps则可以明显提升交互感和逼真感,但是一般来说超过 75fps 一

3、般就不容易察觉到有明显的流畅度提升了。如果帧率超过屏幕刷新率只会浪费图形处理的能力,因为监视器不能以这么快的速度更新,这样超过新率的帧率就浪费掉了。依率莓秒显示的图像数量需要的存储空间&需要的网络布瓦1, 粕法 在规定时间内从一个源到目的/挹制数据的数量(传输点情) 分神率这里阙寒想带我们再展开聊一下视频帧音频帧一般可以独立解码,可以直播播放。而视频分为视频关键帧和非关键帧,关键帧可以独立解码渲染,播放器拿到后可以直接看到画面,一般10K以上甚至几十 K;其他非关键帧解码依赖于前面的一些视频帧,播放器会根据前面的帧和这一帧来解码产生画面,非关键帧一般大小是几 K甚至不到1K。对于播放器来说,服

4、务器一般会从视频关键帧开始发送,这样才不会产生花屏。对于节点上直播服务器存储的内容,如果是文件加速,节点上存储的内容很明确,就是文件数据,URL不变的话文件数据内容也不变。但是对于直播来讲,传输的就是帧数据,缓存的也是不断变化的帧序列数据。下面的图里我们可以看到,当前的服务器缓存了V1-V3五帧数据,当V4这个关键帧出现了,服务器把之前的丢掉,开始缓存 V4开始的音视频数据,以这个策略保证过来的播放端都是当前最新的数据。一般直播服务器都是用这个策略来进行服务器缓存的。下面进入正题,常见的 CDN加速包括文件加速、点播、直播三种业务。最开始阿里云CDN是从文件加速开始,针对的主要是内部客户,像淘

5、宝,它的图片非常多,那时候支持的都是小文件加速。后来随着各BU的端产品衍生,逐渐会支持大的文件下载业务;等阿里云CDN正式作为产品上线商业化时候,开始支持点播业务。2015年下半年,开始支持直播业务。今天阙寒主要从直播概述、直播架构、业务功能和场景来介绍下阿里云 CDN直播系统。直播概述通常,视频直播常见两种形式是手机直播和游戏直播,手淘、陌陌、映客的典型的手机直播平台,游戏直播就是像斗鱼、全民 TV等平台。其实对于播放端来讲,直播和点播都是向服务器获取视频数据,播放端 对声音和画面进行播放的过程。从这个角度来讲,直播和点播区别并不大。那直播和点播究竟区别在哪里?对于视频点播,你在看的时候,你

6、可以随时选择快进和回退。直播却不能。对于视频网站上的视频文件来讲,点播可以选择今天看或明天看,但是直播却不能选择时间,像每周末的联赛只在固定的时间播放。一些机顶盒提供回看的功能,也是点播。所以回归正题,简而言之,直播就是每一帧数据打上时序标签后进行流式传输的过程。发送端源源不断的 采集音视频数据,经过编码、封包、推流、再经过分发网络进行扩散传播,播放端再源源不断地下载数据 并按时序进行解码播放。如此就产生了边生产、边传输、边消费的直播过程。我们将视频直播整个流程主要分为几个关键阶段:视频采集、前处理、编码、推流、转码、分发、播放, 下图为简化版直播系统的基本架构,后面我们再详细展开。果118d

7、B翦RTMP限制语度碑存解喇曲.采集,是视频直播开始的第一个环节,用户可以通过不同的终端采集视频,也就是主播直播的过程。iOS端适配性较好,采集起来比较简单。Android 端因为一直以来市面机型多版本复杂种种情况,加大了一个库适配所有硬件的难度,采集起来相对比较困难。PC端则和摄像头驱动联系紧密,目前市面上最好的PC端源免费软件是OBS。.前处理,业内有一种说法,80%的主播没有美颜根本没法看。所以美颜已经是对视频源进行前处理的标配功能,除此之外还有水印、模糊特效等,针对不同的手机系统提供不同的处理库。白鹉学吧.编码,编码时候我们需要处理的硬件兼容性问题和寻求码率和画质之前的平衡是最大的两个

8、问题。iOS系统硬件兼容性比较好,可以采用硬编,Android 系统则还是因为硬件机型问题,大多采用软编。.推流与转码,在数据传输的整个过程中从主播端到服务器端,再到边缘节点,以及从边缘节点到播放端。为了让采集端的流适配各个平台端不同协议,一般都会在服务端进行转码处理,将视频文件转成不同格式,支持 RTMP、HLS和FLV等不同的协议。.分发,随着移动直播兴起和游戏直播的持续火热,网络直播平台支持亿高并发是理论上应该做到的,为了优化终端观看直播的体验,一般都会采用CDN进行内容分发加速,实现高并发等能力。.客户端播放,也就是解码和渲染,目前iOS端的播放兼容性较好, Android 的硬件解码

9、和编码一样也 存在兼容性问题。通常秒开、低延时等问题是需要在播放端来克服的。直播架构这是一张阿里云直播全景解决方案的图,这里包括详细的推流端推流,直播中心的流存储,转码截图录制等视频处理,CDN智能调度与分发,最后到播放端播放整个过程。50O口。d一 1其M5gR受泣实料料码Am配MftVJ*即管理置*枳时移观,孤旧播放CDN皿分发RTMP HTTP FLV g.O O 6*连量 1M 艇餐置SDKCDNSDK显阳SSDK眇百对于推流端推流,目前主要使用的是 RTMP协议,播放可以使用 RTMP、HTTP FLV和HLS协议, 常用的推流端是 OBS、手机APP、FFmpeg ;播放端包括 F

10、lash、VLC、HTML5、手机APP等形式;视频直播中心拥有稳定的推流上行链路,支持连麦、IM、直播间管理等分丰富的直播服务端实现流能力;CDN直播分发提供流畅的播放下行链路,700多个国内节点和300多个海外节点,还有丰富的小运营商节点。对于播放端,我们做了首屏秒开优化和弱网跳帧播放,确保用户体验。3K白鸽学吧对于视频直播服务器的一个进程上来讲,我们可以认为一个推流端和多个播放端是一种非常典型的发布和 订阅的关系。从下图可以看到,主播完成发布动作,这条直播内容也就是这一路流推动到服务器,三个观众也就是订阅 者,从服务器拉流,也就是用播放动作来完成推流。这种进程内部、节点之间的发布、订阅关

11、系是一种级 联的关系,CDN的直播分发就是依靠这种模式构建。那下面我们从 CDN分发的角度来基础架构是怎样的。内容通过存储集群到达发布集群,再通过骨干中转环境的L2,利用CDN智能调度到达L1,也就是距离用户最近的节点,从顺利的推送给用户。10I白鹉学昭业务功能及场景说完了架构,阙寒带我们来了解业务功能和阿里云CDN的应用场景。对于直播来讲,转码这个业务功能“重要。转码后会在原始流名上加后缀,下图是转码前后的画质、码率的区别。和转码相关的有水印、动模板、延迟转码等功能。截图也是比较重要的业务,比如说直播平台页面分类下有很多张图片,刷新后图片会变化,都是靠周期性截图来完成。除此之外,阿里云也开放

12、对直播进行动态配置、录制、开播断流回调、推流播放鉴权、断流、黑名单、禁播、各种接口 API、转推其他厂商、触发式拉流、连麦、播放纯音频/视频等。113m鸽学吧另外比较重要的是直播数据的监控,对客户和我们来说,能时刻关注直播情况,掌握直播数据,对于防范 问题来说是十分必要的。视频监控是用来记录一路流重要信息,比如常见的视频码率、播放流量和在线人数、视频帧率监控。视频的特性是每秒钟帧率比较固定,视频帧大概是 2030帧/秒,造成卡顿的主要原 因一般是网络链路的抖动,有了全链路秒级帧率监控图之后,排查问题变得非常的方便,针对一路流卡顿以及客户提出的各种问题可以很快的就明确原因。 11 f* - ,

13、1白娘率门正常的监控图应该是一条直线,上图的帧率出现的突刺,就是因为公网网络连接抖动后统计出来的数据降低。对于一路流多个播放端来讲,服务器会不断把帧数据写给播放端,一旦网络抖动,遇到写不出去的情况会将这一帧放到连接的等待队列里,超出了帧队列的长度限制,服务器会选择丢帧。一般这种情况产生是因为网络抖动的比较严重,我们也会以此为依据来确定网络全链路的质量,用红绿颜色来标注区分正常 和非正常的链路质量。那以上的架构和业务功能都可以应用于哪些场景呢?我们也对阿里云视频直播CDN服务的客户场景进行了归类汇总,主要有以下五个方向:12白鹉学吧. UGC互动直播:不仅提供推流到播放的全套直播解决方案,而且集成成熟的互动解决方案,包括IM ,连麦等功能。例如:一直播、映客等直播互动平台。.电商直播:为电商直播提供全套直播解决方案,支持动态扩展的直播技术架构,无需担心直播促销涌入的峰值流量担忧。例如:手淘等电商直播平台。.体育赛事/大型综艺节目直播:为热门的赛事和综艺直播提供动态扩展的直播服务,通过CDN和PCDN的分发,用户无需为突然涌入的流量担忧。例如: CCTV5 ,等电视直播平台。.游戏直播:对游戏直

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论