第一章 RTP 介绍

本章目录

  • 音视频网络简史
  • RTP 简况
  • 相关标准
  • RTP 实现的概述

互联网正在发生改变:静态内容正让位于流媒体视频,文本正在被音乐和语音所取代,大家对交互式音频和视频习以为常。这些变化需要新的应用,这给应用设计人员带来了全新且独特的挑战。

本书描述了如何构建 VOIP、电话、电话会议、流媒体视频和网络广播等这些新型应用, 同时也探讨了在 IP 网络上可靠地传输音频和视频的固有的挑战,并说明了:如何在网络异常面前确保质量,确保系统安全。本书的重点是开放标准,而不是私有解决方案,特别是由互联网工程任务组(IETF)和国际电信联盟(ITU)设计的标准。

本章开头介绍实时传输协议(RTP),并简要回顾了音频/视频网络的历史,最后简述了 RTP 与其他标准的关系。

音视频网络的简介

使用分组网络传输音视频的想法并不新鲜。分组网络上的语音实验可以追溯到 20 世纪 70 年代初。1977年就出现了 第一个关于语音实验的RFC—网络语音协议 。视频会议和流媒体的实验虽然出现的较晚,但也已经有十多年了。

早期的分组语音和视频实验

NVP最初的开发者是在ARPANET上进行分组语音传输的研究人员,ARPANET是互联网的前身。ARPANET提供了可靠流服务(类似于TCP/IP),但这导致了太多的延迟,因此开发了一种类似于现代使用RTP的UDP/IP数据报的“无控制分组”服务。NVP直接在这个无控制分组服务的基础上进行了分层。后来,这些实验扩展到了ARPANET之外,与分组无线电网络和大西洋卫星网络(SATNET)进行了互操作,通过这些网络在NVP上运行。

由于早期网络的带宽都很低,实验都局限于一两个语音通道。20 世纪 80 年代,拥有 3Mbps 宽带的卫星网络的建立使更多的语音通道成为可能,而且还促进了分组视频的发展。人们开发了一种被称为面向连接的互联网络协议的流协议(ST),用来访问卫星网络服务,这种卫星网络只有一跳,带宽预留,支持多播。NVP 的第二个版本(NVP-II)和配套的分组视频协议都通过 ST 交互,这为后面支持分组交换视频的会议服务提供了样板。

在1989年至1990年期间,卫星网络被陆地宽带网络(Terrestrial Wideband Network)和一个名为DARTnet的研究网络所取代,同时ST发展成了ST-II。分组视频会议系统开始定期支持网络研究人员和其他人在最多五个地点参会人同时进行会议。

ST和ST-II在互联网络层与IP并行运行,但仅ST和ST-II只在政府和研究网络上有限度地部署。作为替代方案,DARTnet开始部署在IP网络上,进行视频会议。而通过组播UDP/IP传输数据的NVP-II实现了多方会议。在1992年3月的IETF会议上,音频通过Internet在三个大陆的20个地点进行了组播"隧道"传输,这个"隧道"被称为Mbone(代表"组播骨干"),它是从DARTnet扩展而来的。在同一次会议上,开始了RTP协议的开发。

互联网上的音视频

经过一系列的早期实验,互联网社区对视频会议的兴趣在 20 世纪 90 年代初就开始了。大约在这个时候,工作站和个人电脑的处理能力和多媒体功能已经足以同时采集、压缩和播放音/视频流。与此同时,IP 组播的发展允许将实时数据传输到任意数量的互联网的终端。

众所周知,视频会议和流媒体都是运行良好的多播应用。研究小组着手开发视频会议工具和协议,比如劳伦斯伯克利实验室研发的 vic 和 vat,马萨诸塞大学研发的 nevot, Xerox PARC 研发的 INRIA 视频会议系统和 nv,以及伦敦大学学院研发的 rat。这些工具遵循了一种新的会议方案,基于无连接协议、端到端参数和应用级框架。会议被最低限度地管理,没有准入或最低控制,而且传输层单薄且适应性强。多播既用于广域数据传输,也用作同一机器上应用之间的进程间通信机制(用于在音频和视频工具之间交换同步信息)。由此产生的协作环境由轻度耦合的应用和高度分布式的参与者组成。

多播会议(Mbone)使人们广泛认识到通过 IP 网络传输实时媒体的固有问题:可伸缩的需求,错误恢复和拥塞控制。这些问题直接影响了协议和标准的开发关键点。

RTP 是在 1992-1996 年期间由 IETF 开发的,以 NVP-II 和原始 vat 使用的协议为基础。多播会议采用 RTP 作为唯一的数据传输和控制协议; 因此,RTP 不仅包括媒体发布,还支持会员管理、音视频同步和接收质量报告。

除了用于传输实时媒体的 RTP 之外,还必须开发其他协议来协商和控制媒体流。会话通知协议(SAP)是为了通知多播数据流而开发的。会话通知本身就是多播的,任何具有多播能力的主机都可以接收 SAP 通知并会议和传输的内容。在通知中,会话描述协议(SDP)描述了发送端和接收端在多播会话中使用的传输地址以及压缩/分组方案。多播部署的缺乏和万维网的兴起在很大程度上取代了分布式多播目录的概念,但 SDP 在今天仍被广泛使用。

最后,Mbone 社区主导了会话发起协议(SIP)的开发。SIP 用来作为一种轻量级的方法来查找参与者,并让一组指定的参与者开始多播会话。在早期的版本中,SIP 几乎不包括呼叫控制和协商的支持,因为这些方面在 Mbone 会议也没有。现在,SIP已经成为一个更全面的协议,包括广泛的协商和控制功能。

ITU Standards

与早期分组语音工作并行的是**综合业务数字网(ISDN)**的发展,ISDN是普通老式电话系统的数字版本,也是视频会议标准。这些标准基于 ITU 的提案 H.320,使用电路交换链路,因此与我们对分组音频和视频的讨论没有直接关系。然而,他们开创了许多今天大量使用的压缩算法(例如 H.261 视频)。

因特网的发展和商业世界中局域网设备的广泛部署促使国际电联扩展 H.320 系列协议。具体说来,他们试图使协议适合于“提供无保证服务质量的局域网”,IP 是一个符合描述的经典协议族。这也引起了 H.323 的系列提案书的诞生。

H.323 于 1997 年首次出版,此后几经修改。它提供了一个由媒体传输、呼叫信令和会议控制组成的框架。信令和控制功能在 ITU 提案书 H.225.0 和 H.245 中定义。最初,信令协议主要集中在使用 H.320 与 ISDN 会议的互操作上,结果导致繁琐的会话设置过程,该标准的后续版本简化了这一过程。关于媒体传输,电信联盟工作组采纳了 RTP。然而,H.323 只使用了 RTP 的媒体传输功能,很少使用控制和报告元素。

H.323 在市场上取得了一定的成功,有几个硬件和软件产品是为支持 H.323 技术套件而构建的。开发体验导致了对其复杂性的抱怨,特别是 H.323 版本的复杂设置过程和对信令使用的二进制消息格式。其中一些问题在后来的 H.323 版本中得到了解决,但在此期间,人们对替代方案的兴趣有所增加。

其中一个我们已经提到过的替代方案是 SIP。最初的 SIP 规范是 IETF 在 1999 年发布的,它是一个学术研究项目的成果,几乎没有商业利益。此后,在很多领域,它都被视为 H.323 的替代品,并被应用于更多样化的应用中,比如短信系统和 ip 电话。此外,SIP正在被考虑用于第三代移动电话系统,并已获得相当多的行业支持。

国际电信联盟最近提出了提案 H.332,它结合了紧密耦合的 H.323 会议和轻量级多播会议。该结果对于在线研讨会等场景非常有用,在在线研讨会中,会议的 H.323 部分允许一组发言者之间的密切交互,而被动的观众则通过多播观看。

音视频流

在多播会议和 H.323 发展的同时,万维网革命也发生了,它为因特网带来了精美的内容, 公众也开始普遍接受因特网。网络带宽和终端系统容量方面的进步使流媒体音频和视频与网页同时传输成为可能,RealAudio 和 QuickTime 等系统在这方面处于领先地位。这类系统的市场不断增长,促使人们希望为流媒体内容设计一种标准的控制机制。结果是实时流协议(RTSP),它能提供流媒体演示的启动和类似于录像机的控制; RTSP 于 1998 年标准化。RTSP 建立在现有的标准之上: RTSP行为上非常类似于 HTTP,但RTSP用 SDP 进行会话描述, RTP 进行媒体传输。

RTP 简况

IP 网络中音频/视频传输的关键标准是实时传输协议(RTP)及其相关配置文件和有效负载格式。RTP 旨在通过 IP 网络建立传输实时媒体传输服务,如音频和视频。这些服务包括定时恢复、丢包检测和恢复、负载和源标识、接收质量反馈、媒体同步和会员管理。RTP 最初设计用于多播会议,使用轻量级会话模型。从那时起,它已被证明对一系列其他应用有用: H.323 视频会议、网络广播和电视分发; 有线电话和移动电话都是如此。该协议已被证明可以从点对点使用扩展到具有数千用户的多播会话,从低带宽蜂窝电话应用扩展到以千兆比特速率传输未压缩的高清晰度电视(HDTV)信号。

RTP 是由 IETF 的音频/视频传输工作组开发的,后来被国际电联作为其 H.323 系列提案的一部分而采用,并被其他各种标准组织采用。RTP 的第一个版本是在 1996 年 1 月完成的,在完成之前需要对特定用途的 RTP 进行概要分析; RTP 规范定义了一个初始概要,还有几个概要正在开发中。附带几个负载格式规范的配置文件描述了特定媒体格式的传输。RTP 的开发正在进行中,在撰写本文时,一个修订已经接近完成。

在第三章会详细介绍 RTP,即实时传输协议,本书的大部分内容讨论了使用 RTP 的系统的设计及其各种扩展。

相关标准

除了 RTP 之外,完整的系统通常还需要使用各种其他协议和标准来进行会话通知、启动/控制、媒体压缩和网络传输。

图 1.1 描绘了IETF 和国际电信联盟会议框架,这个框架包含了协商和呼叫控制协议、媒体传输层(由 RTP 提供)、压缩解码算法(codecs)和底层网络之间的关系。这两套并行的呼叫控制和媒体协商标准使用相同的媒体传输框架。不管会话是如何协商的,也不管底层网络传输是什么,媒体编解码器都是通用的。

这些标准与RTP的关系在第3章“实时传输协议”中有详细描述。不过,本书的主要关注点在于媒体传输,而不是信号和控制。

RTP 实现的概述

如图 1.1 所示,任何通过IP网络传输实时音频/视频的系统的核心都是 RTP: 它提供公共的媒体传输层,独立于信令协议和应用。在我们更详细地研究 RTP 和使用 RTP 的系统设计之前,有必要了解一下系统中 RTP 发送端和接收端的职责。

RTP 发送端的行为

发送端负责采集和转换用于传输的视听数据,以及生成 RTP 包。它还可以通过调整传输的媒体流以响应接收端的反馈来参与错误恢复和拥塞控制。发送过程的关系如图 1.2 所示。

未压缩的媒体数据(音频或视频)被采集到缓冲区中,压缩为数据帧。数据帧帧可以根据使用的压缩算法以多种方式进行编码,编码后的帧可能同时依赖于之前和之后的数据。

压缩帧被装入 RTP 包中,准备发送。如果帧很大,它们可能被分成几个 RTP 包; 如果它们很小,可以将几个帧绑定到一个 RTP 包中。根据配套的错误恢复方案,可以使用信道编码器来生成错误恢复包或在传输之前重新对包进行排序。

发送 RTP 包之后,与这些包对应的缓冲媒体数据最后会被释放。发送端不能丢弃可能需要用于错误恢复或编码的数据。这意味着发送端在发送了相应的数据包之后,必须将数据缓存一段时间,这个时间取决于所使用的编解码器和错误恢复方案。

发送端负责生成它所生成的媒体流的定期状态报告,包括唇音同步所需的媒体流。它还从其他参与者那里收到接收质量反馈,并可能利用这些信息来调整其传输。

RTP 接收端的行为

接收端负责从网络中收集 RTP 数据包,恢复丢失的数据,纠正时序,解码媒体,并将结果显示给用户。同时,接收端还需要发送接收质量反馈,帮助发送端调整往接收端的传输策略,并维护会话中参与者的数据库。接收过程方框图如图 1.3 所示; 但是具体实现有时根据需要以不同的顺序执行操作。

接收过程的第一步是收集来自网络的数据包,验证它们的正确性,并将它们插入到特定发送端的输入队列中。从输入队列中收集数据包,并将其传递给可选的信道编码例行程序以恢复丢失的数据。在到达编码器之后,数据包被插入到指定源的播放缓冲区中。播放缓冲区按时间戳排序,将数据包插入缓冲区的过程纠正了传输期间引起的排序错乱。数据包一直保留在播放缓冲区中,直到接收到完整的帧为止。除此之外,还对缓存数据帧,以消除由网络引起的包间到达时间抖动。计算要在各个步骤内部延迟量是 RTP 实现设计中最关键的方面之一。每个包都用相应帧所需的播放时间进行标定。

当数据包的播放时间到达后,这些包形成完整的帧,我们也需要修复损坏或丢失的帧。在进行任何必要的修复之后解码数据帧(根据使用的编解码器,在修复丢失的帧之前可能需要解码媒体)。在这一点上,发送端和接收端的名义时钟速率可能有明显的差异。这些差异表现为 RTP 媒体时钟相对于播放时钟的值的偏移。接收端必须补偿这个时钟偏差,以避免在播放中出现间隙。

从这篇简短的概述中可以明显看出,RTP 接收端的操作很复杂,它比发送端的操作更加复杂。这种复杂性的增加主要是由于 IP 网络的不确定性(大部分复杂性来自于补偿丢失的包的需要,以及恢复受抖动影响的流的时序)。

总结

本章介绍了通过 IP 网络实时传输多媒体的协议和标准,特别是实时传输协议(RTP)。本书的其余部分将详细讨论 RTP 的特性和使用。其目的是扩展标准文档,解释标准背后的基本原理和可能的实现选择及其权衡。