词条 | rtcp |
释义 | RTCP的实现(一.Introduction 二.RTCP的传输 三.RTCP的包格式 四.Security and Privacy 五.Packet Validation 六.参与者数据库 七.Timing Rule) 概述RTCP:RTP 控制协议 (RTCP:RTP Control Protocol) RTP 控制协议(RTCP)采用与数据包相同的分发机制,将控制包周期性传输到所有会话参与者中。底层协议必须提供数据和控制包的多路发送,例如使用不同的 UDP 端口号。 RTCP 提供数据分发质量反馈信息,这是 RTP 作为传输协议的部分功能并且它涉及到了其它传输协议的流控制和拥塞控制。 RTCP 为 RTP 源携带一个持久性传输层标识符,称为规范名或 CNAME 。由于一旦发现冲突或程序重启时, SSRC 标识符会随之改变,所以接收方需要 CNAME 来跟踪每一个参与者。同时接收方还要求 CNAME 能够与一组相关 RTP 会话中来自于给定参与者的多重数据流相关联,例如同步视频和音频。 上述前两个功能要求所有的参与者都要发送 RTCP 包,因此必须控制速率以便 RTP 按比例增加大量的参与者。通过每一个参与者发送各自的控制包给其它所有参与者,每一个参与者能够独立观察到参与者数量,该数量可用来计算控制包的发送速率。 OPTIONAL 功能用于传送最少会话控制信息,例如在用户界面显示参与者标识。这对于“松散受控”会话(在没有成员控制或阐述协商的情况下,参与者可以加入或退出该会话)是非常有用的。 上述功能 1 - 3 适用于所有环境,尤其是 IP 组播环境。 RTP 应用程序设计者应该避免设计只能工作于单播模式并且不能增加到大量数量的机制。在某些情况下如单向链接中,不可能有来自接收方的反馈,所以 RTCP 的传输就可能由发送方和接收方分别独立控制。 协议结构定义单位(bit) version p rc packet 2 3 8 16 LengthVersion ― 识别 RTP 版本。 RTP 数据包中的该值与 RTCP 数据包中的一样。 当前规范定义的版本值为 2 。 P ― 间隙(Padding)。设置时, RTCP 数据包包含一些其它 padding 八位位组,它们不属于控制信息。 Padding 的最后八位是用于计算应该忽略多少间隙八位位组。一些加密算法中需要计算固定块大小时也可能需要使用 Padding 字段。在一个复合 RTCP 数据包中,只有最后的个别数据包中才需要使用 padding ,这是因为复合数据包是作为一个整体来加密的。 RC ― 接收方报告计数。包含在该数据包中的接收方报告块的数量,有效值为 0 。 Packet type ― 包括常量 200 ,识别这是一个 RTCP SR 数据包。 Length ― RTCP 数据包的大小(32 位字减去 1),包含头和任意间隙 (偏移量的引入使得 0 成为有效值,并避免了扫描复合 RTCP 数据包过程中的无限循环现象,而采用 32 位字计数方法则避免了对 4 的倍数的有效性校验)。 RTCP的实现一.IntroductionAn RTCP implementation has three parts: the packet formats, the timing rules, and the participant database Packet Formats: Timing Rules: 所有的RTCP复合包被周期性送出,这个周期称为reporting interval,所有的RTCP活动都是以这个间隔发生的, 除了update of source description 和lip synchronization information,以及在这个interval内发生的reception quality statistics. Participant Database: 基于收到的RTCP包建立的. 1.根据这个db可以填充Reception Report,并发送给对方 2.可以维护Participant Information 3.可以用于进行lip synchronization. 二.RTCP的传输1.必须发送RTCP compound包, 2.odd ports, 是RTP port + 1(最近不要求必须是奇数,也不要求必须大1了) 3.所有的参与者应当送出compound packets,也接收所有其他的participants发送的compound packets, Note that feedback is sent to all participants in a multiparty session: either unicast to a translator, which then redistributes the data, or directly via multicast. The peer-to-peer nature of RTCP gives each participant in a session knowledge of all other participants: their presence, reception quality, and—optionally—personal details such as name, e-mail address, location, and phone number. 三.RTCP的包格式SR,RR,SDES,BYE,APP 通用头(固定头):4 octets v p ic pt length(be measured in units of 32-bits word) 2 1 5 8 16 ---------- p c(8) 1.RR(Receiver Report) Reception quality reporting:所有发送RTP数据的Sender的信息,每个block包含一个SSRC的RTP接受质量报告 PT = 201 Format: Reporter SSRC *{//一个Reporter Block 固定头 24 octets的内容 包括以下部分: reportee SSRC: cumulative number of packets lost :24bit的有符号数,从会话开始到现在期望收到-实际收到(可为负) extended highest sequence number :per session loss fraction :per interval, 取整 [丢包/期望收到数目 * 256](如果丢包为负值,则结果设为0) interarrival jitter : last sender report timestamp(LSR) :从reportee端最后收到的Sender Report中NTP timestamp的中32bits.(无则为0) delay since last sender report(DLSR) :最后收到SR和发送RR之间的间隔,以1/65536为单位(否则为0) } RR的解释 这是一个接收质量的反馈,对Sender和其他的第三方如网络的monitor等都有意义 如: 1)可以计算Round-trip Time (RR收到时间-LSR - DLSR),round-trip time的估计是很重要的 2)Lost fraction:短期内,对媒体格式的选择有参考 3)Jitter:突然增大的Jitter通常意味着丢包的开始 SR(Sender Report) Sender Report 提供了有关Sender所发送的媒体的信息,主要用于进行多个媒体流同步等. PT = 200 Format: 固定头 Reporter SSRC NTP Timestamp(2 octets):发送SR的NTP RTP Timestamp: 与previous field同一时刻,但是单位是RTP Media clock Sender's packet count:自会话开始 Sender's octet count:自会话开始 SR的解释 计算速率等 媒体时钟和NTP时钟 3.SDES: Source Description 用于提供参与者的详细信息,通常是人可读的,如email,电话等,依赖于应用. PT = 202 Format: 固定头 *{ SSRC/CSRC List of SDES items } Items中每个entry如下: Type Length content 8 8 Type == 0 表示Lists结束 RFC中规定了一些Items如:CNAME, NAME, EMAIL, PHONE, LOC, TOOL, NOTE, and PRIV. 4.RTCP BYE: Membership Control 通常用于指示会话中的某个成员正在离开. 但是RTCP BYE的含义在某种程度上是依赖于应用的,应用通常有其他的控制协议如SIP,H323等控制会话. 记住BYE不终止会话成员的关系,只是表示正在离开,并且不保证传输肯定到达. PT=203 Format: 固定头 *{ SSRC } 可选长度,可选原因 5.RTCP APP: Application-Defined RTCP Packets PT=204 6.Compound Packet 以上的RTCP包从不单独发送,它们被打包成复合包(Compound Packet)来发送,有几个规则. 1)对活动的发送者(active data sender),compound必须以SR开始,否则以RR开始,即使没有数据接收和发送.后面跟着*个RR. 2)然后是SDES,SDES必须包含一个CNAME,其他可选. 3)如果有BYE的话,放到最后.其他的包可以随意. RTCP Packet从来不单独传输,他们按照一定的规则总是组成Compound Packet来传送.下面介绍这个规则: 1)最前面可以有个可选的32位值(在RTCP compound packet加密时使用) 四.Security and PrivacySDES的传输中暴露隐私,这是个问题.但是CNAME是必须的. 五.Packet Validation1.所有的包必须是复合包 2.版本必须是2 3.复合包开始的RTCP Packet必须是SR和RR 4.如果需要Padding,则只有最后一个packet是padding的. 5.所有的RTCP packets的长度必须等于复合RTCP包的长度. 六.参与者数据库参与者和会话的信息 1.RTCP的全局配置信息 1)The RTP bandwidth 1)RTCP所占总带宽的比例(这意味必须知道RTP所占的总带宽):default 0.05 2)发送间隔:default 5s(最小) 3)发送部分所占的比例:default 0.025 4)The average size of all RTCP packets sent and received by this participant. 5)The number of members in the session, the number of members when this participant last sent an RTCP packet, and the fraction of those who have sent RTP data packets during the preceding reporting interval. 6)The time at which the implementation last sent an RTCP packet, and the next scheduled transmission time. 8)A flag indicating whether the implementation has sent any RTP data packets since sending the last two RTCP packets. 9)A flag indicating whether the implementation has sent any RTCP packets at all. 10)The number of packets and octets of RTP data it has sent. 11)The last sequence number it used. 12)The correspondence between the RTP clock it is using and an NTP-format timestamp. 会话中每个成员的信息 1)SSRC identifier. 2)Source description information: the CNAME is required; other information may be included (note that these values are not null-terminated, and care must be taken in their handling). 3)Reception quality statistics (packet loss and jitter), to allow generation of RTCP RR packets. 4)Information received from sender reports, to allow lip synchronization (see Chapter 7). 5)The last time this participant was heard from so that inactive participants can be timed out. 6)A flag indicating whether this participant has sent data within the current RTCP reporting interval. 7)The media playout buffer, and any codec state needed (see Chapter 6, Media Capture, Playout, and Timing). 8)Any information needed for channel coding and error recovery—for example, data awaiting reception of repair packets before it can 七.Timing Rule总的目标是限制RTCP占RTP会话量的一小部分,通常是5%.在这个目标的前提下,参与者送出RTCP packet的速率是不固定的,而是变化了,如对有大量的listener的Internet Radio,客户端可能几分钟才发送,而对two-party的电话可能是几秒钟. 有一些规则可以参考,这些规则可以确保实现的可缩放性(Scalability). 1.Reporting Interval 根据以下几个部分来计算: 1).The bandwidth allocated to RTCP:5%通常 * Session带宽 2).The average size of RTCP packets sent and received:包括所有头(UDP,IP) 3).The total number of participants and the fraction of those participants who are senders 在计算时, SNo:Sender Number ANo:所有参与者数目 RNo:Receiver Number Intl:Interval ARS:average RTCP size RW:RTCP bandwidth if (senders > 0 && senders <= (25% of total number of participants) { if (we are sending) { Interval = average RTCP size * senders / (25% of RTCP bandwidth) } else { Interval = average RTCP size * receivers / (75% of RTCP bandwidth) } } else if ((senders = 0) or (senders > (25% of total number of participants)) { Interval = average RTCP size * total number of members / RTCP bandwidth } 这样可以确保Sender即使很少的情况下也可以确保25%的带宽,能够送出足够的lip synchronization信息 If (Interval < minimum interval) { Interval = minimum interval } 当会话中的参与者的数目或者sender所占比例发生变化时,报告间隔应当重新计算. 2.Basic Transmission Rules 基本的传输规则就是: I = (Interval * random[0.5, 1.5]) if (this is the first RTCP packet we are sending) { I *= 0.5 } next_rtcp_send_time = current_time + I 对于有很多参与者,并且数目还在变化的会话,每次发送当前的RTCP Packet后,根据得到的Participants Number来计算. 3.Forward Reconsideration 当会话中同时到来大量的Participant时,造成网络拥塞(Called as "step join"),为此使用Forward Reconsideration 方法: 在每次发送前,根据当前的会话信息重新计算发送时间, if (current_time >= next_rtcp_check_time) {//1.21828是一个补偿因子 new_rtcp_send_time = (rtcp_interval() / 1.21828) + last_rtcp_send_time if (current_time >= new_rtcp_send_time) { send RTCP packet next_rtcp_check_time = (rtcp_interval() /1.21828) + current_time } else { next_rtcp_check_time = new_send_time } } 4.Reverse Reconsideration 当大量的人同时离开时,导致RTCP所占带宽过低(Called as "step leave"). 为此,当BYE来时,立即重新计算下个包的发送时间. 5.BYE Reconsideration 大量的BYE,为此可以:延迟BYE的发送,或者干脆不发送. 6.Comments on Reconsideration 各个实现应该考虑这个问题,并尽可能的使用各个Reconsideration. 7.Common Implementation Problems 1)没有正确的考虑参与者的数目,固定的Reporting Interval会导致流量呈线性增长. 2)Reporting interval没有随机化.有潜在的可能:同步他们的reports,导致 3)在带宽计算时未考虑Headers(IP,UDP)等 4)padding使用不正确 |
随便看 |
百科全书收录4421916条中文百科知识,基本涵盖了大多数领域的百科知识,是一部内容开放、自由的电子版百科全书。