大型视频直播平台架构由浅入深详细讲解

大型视频直播平台架构由浅入深详细讲解

直播平台整体架构

注解:native&h5,原生开发和符合开发模式

视频直播链路

大型视频直播平台架构由浅入深详细讲解

视频直播链路

用户通过CDN(内容分发网络),提高接入速度,避免网段访问。

训练深度学习神经网络进行分类,自动识别色情内容。

支持不同协议访问,满足延时需求。

分发网络-多集群源站设计

大型视频直播平台架构由浅入深详细讲解

分发网络-多集群源站设计

播放器的基本实现

大型视频直播平台架构由浅入深详细讲解

播放器的基本实现

三、常见的视频直播相关协议:

1、RTMP(Real Time Messaging Protocol,实时消息传送协议)

RTMP是Adobe Systems公司为Flash播放器和服务器之间音频、视频和数据传输开发的开放协议。它有三种变种:

1)、工作在TCP之上的明文协议,使用端口1935;

2)、RTMPT封装在HTTP请求之中,可穿越防火墙;

3)、RTMPS类似RTMPT,但使用的是HTTPS连接;

RTMP协议是被Flash用于对象、视频、音频的传输。这个协议建立在TCP协议或者轮询HTTP协议之上。RTMP协议就像一个用来装数据包的容器,这些数据既可以是AMF格式的数据,也可以是FLV中的视音频数据。一个单一的连接可以通过不同的通道传输多路网络流,这些通道中的包都是按照固定大小的包传输的。

2、RTSP(Real Time Streaming Protocol,实时流传输协议)

RTSP定义了一对多应用程序如何有效地通过IP网络传送多媒体数据。RTSP提供了一个可扩展框架,数据源可以包括实时数据与已有的存储的数据。该协议目的在于控制多个数据发送连接,为选择发送通道如UDP、组播UDP与TCP提供途径,并为选择基于RTP上发送机制提供方法。

RTSP语法和运作跟HTTP/1.1类似,但并不特别强调时间同步,所以比较能容忍网络延迟。代理服务器的缓存功能也同样适用于RTSP,并且因为RTSP具有重新导向功能,可根据实际负载情况来切换提供服务的服务器,以避免过大的负载集中于同一服务器而造成延迟。

3、RTP(Real-time Transport Protocol,实时传输协议)

RTP是针对多媒体数据流的一种传输层协议,详细说明了在互联网上传递音频和视频的标准数据包格式。RTP协议常用于流媒体系统(配合RTCP协议),视频会议和一键通系统(配合H.323或SIP),使它成为IP电话产业的技术基础。

RTP是建立在UDP协议上的,常与RTCP一起使用,其本身并没有提供按时发送机制或其它服务质量(QoS)保证,它依赖于低层服务去实现这一过程。

RTP 并不保证传送或防止无序传送,也不确定底层网络的可靠性,只管发送,不管传输是否丢包,也不管接收方是否有收到包。RTP 实行有序传送,RTP中的序列号允许接收方重组发送方的包序列,同时序列号也能用于决定适当的包位置,如在视频解码中,就不需要顺序解码。

4、RTCP(Real-time Transport Control Protocol,实时传输控制协议)

RTCP是RTP的配套协议,为RTP媒体流提供信道外的控制。RTCP和RTP一起协作将多媒体数据打包和发送,定期在多媒体流会话参与者之间传输控制数据。

RTCP的主要功能是为RTP所提供的服务质量(QoS)提供反馈,收集相关媒体连接的统计信息,例如传输字节数,传输分组数,丢失分组数,单向和双向网络延迟等等。网络应用程序可以利用RTCP所提供的信息来提高服务质量,比如限制流量或改用压缩比小的编解码器。

大型视频直播平台架构由浅入深详细讲解

 

视频流转换成不同清晰度

不同的端,不同的网络环境,需要不同码率,以保流畅

大型视频直播平台架构由浅入深详细讲解

视频流转换成不同清晰度

SDK在播放器上做层管理

大型视频直播平台架构由浅入深详细讲解

SDK在播放器上做层管理

消息发送流程

大型视频直播平台架构由浅入深详细讲解

消息发送流程

消息投递先过滤;消息队列,削峰填谷;多线程处理消息发送;房间分桶,降低下行压力;不同的消息通道,对消息发送方透明。

不同消息通道的优劣对比

大型视频直播平台架构由浅入深详细讲解

不同消息通道的优劣对比

大促风险控制

大型视频直播平台架构由浅入深详细讲解

 

平台化的挑战

大型视频直播平台架构由浅入深详细讲解

 

视频直播的工作原理

大型视频直播平台架构由浅入深详细讲解

视频直播的工作原理

以上内容,参考了许多很多网友同行的资料,如有侵权,造成损失,提供资料后,请联系。

原文地址:https://www.cnblogs.com/wangsongbai/p/10330114.html