视频直播技术总结分享

2017-08-14 20:40:08 +08:00
 imzhibo

一、直播的技术架构: 直播视频采集 SDK ( PC/IOS/Anddroid )——直播 CDN

(直播流分发加速)——直播视频播放器 SDK ( PC/IOS/Android )

二、音视频处理的一般流程:

数据采集→数据编码→数据传输(流媒体服务器) →解码数据→播放显示

1、数据采集:

摄像机及拾音器收集视频及音频数据,此时得到的为原始数据

涉及技术或协议:

摄像机:CCD、CMOS

拾音器:声电转换装置(咪头)、音频放大电路

2、数据编码:

使用相关硬件或软件对音视频原始数据进行编码处理(数字化)及加工(如音视频混合、打包封装等),得到可用的音视频数据

涉及技术或协议:

编码方式:CBR、VBR 编码格式 视频:H.265 、H.264 、MPEG-4 等,封装容器有 TS、MKV、AVI、MP4 等 音频:G.711μ、AAC、Opus 等,封装有 MP3、OGG、AAC 等

3、数据传输:

将编码完成后的音视频数据进行传输,早期的音视频通过同轴电缆之类的线缆进行传输,IP 网络发展后,使用 IP 网络优传输

涉及技术或协议:

传输协议:RTP 与 RTCP、RTSP、RTMP、HTTP、HLS ( HTTP Live Streaming )等

控制信令:SIP 和 SDP、SNMP 等

4、解码数据:

使用相关硬件或软件对接收到的编码后的音视频数据进行解码,得到可以直接显示的图像 /声音

涉及技术或协议:

一般对应的编码器都会带有相应的解码器,也有一些第三方解码插件等

5、播放显示:

在显示器(电视、监视屏等)或扬声器(耳机、喇叭等)里,显示相应的图像画面或声音

涉及技术或协议:

显示器、扬声器、3D 眼镜等

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

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 和 api 接口,开发者接入后就可以实现直播的功能。欢迎相互交流学习。我的 qq2479775187

2654 次点击
所在节点    云计算
6 条回复
Kaiyuan
2017-08-14 21:35:11 +08:00
我一直想知道电脑上有没有低成本的多机位镜头切换和画面合成的途径。特别过场和镜头切换效果,多镜头同屏之类。OBS Studio 有个简单的场景切换。
iRiven
2017-08-14 22:28:02 +08:00
总结的很好 收藏了
luulsj
2017-08-15 09:35:46 +08:00
所以,你们团队叫什么?
TuSDK
2017-08-15 10:19:15 +08:00
抓重点,直播视频采集 SDK,O(∩_∩)O 哈哈哈~
CareiOS
2017-08-15 10:31:24 +08:00
给钱才会与你交流。
siyiye
2017-08-16 20:30:42 +08:00
@Kaiyuan 采集卡?

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/382897

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX