jrtplib3.11.1之 源码分析(二):数据包

RTP 头部

  • rtpstructs : 数据结构体
struct RTPHeader
{
#ifdef RTP_BIG_ENDIAN
    uint8_t version:2;
    uint8_t padding:1;
    uint8_t extension:1;
    uint8_t csrccount:4;
    
    uint8_t marker:1;
    uint8_t payloadtype:7;
#else // little endian
    uint8_t csrccount:4;
    uint8_t extension:1;
    uint8_t padding:1;
    uint8_t version:2;
    
    uint8_t payloadtype:7;
    uint8_t marker:1;
#endif // RTP_BIG_ENDIAN
    
    uint16_t sequencenumber;
    uint32_t timestamp;
    uint32_t ssrc;
};
image.png
image.png
  • V - Version. Identifies the RTP version.
    RTP版本号

  • P - Padding. When set, the packet contains one or more additional padding octets at the end which are not part of the payload.
    是否填充,如果设置为允许填充的话,在包的末尾填充一个或多个字节,这些填充的字节不是有效负载的一部分。

  • X - Extension bit. When set, the fixed header is followed by exactly one header extension, with a defined format.
    扩充位,如果设置为允许的话,固定头结构后面(即包的12个字节后面,有效负载的前面)紧跟着一个扩展头结构,该结构是已定义的一种格式

  • CSRC count (CC) -Contains the number of CSRC identifiers that follow the fixed header.
    数据源的个数(即源的个数),如果只有一个源那么此时的值为0。

  • M - Marker. The interpretation of the marker is defined by a profile. It is intended to allow significant events such as frame boundaries to be marked in the packet stream.
    标识,在文档中是这样定义的,它有意标识重要的事物比如:在流媒体中标识一帧数据的边界(结束或开始)。

  • Payload type - Identifies the format of the RTP payload and determines its interpretation by the application. A profile specifies a default static mapping of payload type codes to payload formats. Additional payload type codes may be defined dynamically through non-RTP means.
    有效负载,RTP数据的有效负载(不包括头12个字节),由具体的应用程序来确定负载的格式和意义。官方文档里有表格说明,该表格显示了格式代码和具体格式的对应关系,附加的格式代码可能不在RTP协议里定义。

  • Sequence number - Increments by one for each RTP data packet sent, and may be used by the receiver to detect packet loss and to restore packet sequence.
    数据包序号,发送的RTP数据包序号,接收端可用它来检查丢失的数据包和确定保存数据包次序。

  • Timestamp - Reflects the sampling instant of the first octet in the RTP data packet. The sampling instant must be derived from a clock that increments monotonically and linearly in time to allow synchronization and jitter calculations.
    时间戳,纪录了RTP数据包中第一个字节的采样时间,采样时间必须源自一个时间增量且允许同步和计算。

  • SSRC - Synchronization source. This identifier is chosen randomly, with the intent that no two synchronization sources within the same RTP session will have the same SSRC identifier.
    同步标识,是一个随机数,在同一个RTP会话中只有一个同步标识。

  • CSRC - Contributing source identifiers list. Identifies the contributing sources for the payload contained in this packet.
    数据源标识,保存着数据源的列表,在RTP里的每个包里都包含了对应数据源的ID。

  • RTPExtensionHeader X - Extension bit

struct RTPExtensionHeader
{
    uint16_t extid;
    uint16_t length;
};
  • RTCPCommonHeader RTCP通用头部
struct RTCPCommonHeader
{
#ifdef RTP_BIG_ENDIAN
    uint8_t version:2;
    uint8_t padding:1;
    uint8_t count:5;
#else // little endian
    uint8_t count:5;
    uint8_t padding:1;
    uint8_t version:2;
#endif // RTP_BIG_ENDIAN

    uint8_t packettype;
    uint16_t length;
};

RTP包

  • rtprawpacket : 用来存储RTP和RTCP数据

    1. 数据指针 packetdata
    2. 数据长度 packetdatalength
    3. 接收时间 receivetime
    4. 网络地址 senderaddress
    5. 是否是rtp数据包 isrtp
  • rtppacket :用于解析RTPRawPacket的实例,可以得到rtp header 信息。该类也可以根据指定的参数来创建一个新的RTP数据包。

  • rtppacketbuilder :这个类可以用来建立RTP包,比RTPPacket类高一级,它会产生一个SSRC标识符,跟踪时间戳和序列号等, 打成一组包。

RTCP 实时传输控制协议类

RTCP 控制协议需要与RTP数据协议一起配合使用,当应用程序启动一个RTP会话时将同时占用两个端口,分别供RTP和RTCP使用。RTP本身并不能为按序传输数据包 提供可靠的保证,也不提供流量控制和拥塞控制,这些都由RTCP来负责完成。通常RTCP会采用与RTP相同的分发机制,向会话中的所有成员周期性地发送控制信息,应用程序通过接收这些数据,从中获取会话参与者的相关资料,以及网络状况、分组丢失概率等反馈信息,从而能够对服务质量进行控制或者对网络状况进行诊断。

RTCP协议的功能是通过不同的RTCP数据报来实现的,主要有如下几种类型:

  • SR 发送端报告:所谓发送端是指发出RTP数据报的应用程序或者终端,发送端同时也可以是接收端。
  • RR 接收端报告:所谓接收端是指仅接收但不发送RTP数据报的应用程序或者终端。
  • SDES 源描述:主要功能是作为会话成员有关标识信息的载体,如用户名、邮件地址、电话号码等,此外还具有向会话成员传达会话控制信息的功能。
  • BYE 通知离开:主要功能是指示某一个或者几个源不再有效,即通知会话中的其他成员自己将退出会话。
  • APP 由应用程序自己定义:解决了RTCP的扩展性问题,并且为协议的实现者提供了很大的灵活性。

RTCP数据报携带有服务质量监控的必要信息,能够对服务质量进行动态的调整,并能够对网络拥塞进行有效的控制。由于RTCP数据报采用的是多播方式,因此会话中的所有成员都可以通过RTCP数据报返回的控制信息,来了解其他参与者的当前情况。

在一个典型的应用场合下,发送媒体流的应用程序将周期性地产生发送端报告SR,该RTCP数据报含有不同媒体流间的同步信息,以及已经发送的数据报和字节的计数,接收端根据这些信息可以估计出实际的数据传输速率。另一方面,接收端会向所有已知的发送端发送接收端报告RR,该RTCP数据报含有已接收数据报的最大序列号、丢失的数据报数目、延时抖动和时间戳等重要信息,发送端应用根据这些信息可以估计出往返时延,并且可以根据数据报丢失概率和时延抖动情况动态调整发送速率,以改善网络拥塞状况,或者根据网络状况平滑地调整应用程序的服务质量。

  • rtcppacket: RTCP包的特定类型的基类。 数据指针 数据长度 数据类型
    enum PacketType  //类型
    { 
            SR,         /* RTCP sender report. */
            RR,         /* RTCP receiver report. */
            SDES,    /* RTCP source description packet. */
            BYE,       /* RTCP bye packet. */
            APP,       /* RTCP packet containing application specific data. */
            Unknown    /*The type of RTCP packet was not recognized. */
    };
  • rtcpcompoundpacket : 表示一个RTCP复合包 是由一系列的 RTCPCommonHeader + rtcp数据包组成 (SR, RR,....), 解析接收到数据 把rtcp数据包添加到rtcppacklist链表中 可以循环遍历。

  • RTCPAPPPacket : RTCP APP packet

  • RTCPBytePacket : RTCP Byte packet

  • RTCPRRPacket: RTCP receiver report packet

  • RTCPSRPacket: RTCP sender report packet

  • RTCPSDESPacket: RTCP source description packet

  • RTCPUnknownpacket:RTCP packet of unknown type

继承RTPSession类,然后可以通过实现OnRTCPCompoundPacket来获取相关的RTCP反馈。

LIBRTP内部使用的结构体

  • RTCPSenderReport 结构体
struct RTCPSenderReport
{
    uint32_t ntptime_msw;
    uint32_t ntptime_lsw;
    uint32_t rtptimestamp;
    uint32_t packetcount;
    uint32_t octetcount;
};
  • RTCPReceiverReport
struct RTCPReceiverReport
{
    uint32_t ssrc; // Identifies about which SSRC's data this report is...
    uint8_t fractionlost;
    uint8_t packetslost[3];
    uint32_t exthighseqnr;
    uint32_t jitter;
    uint32_t lsr;
    uint32_t dlsr;
};
  • RTCPSDESHeader
struct RTCPSDESHeader
{
    uint8_t sdesid;
    uint8_t length;
};
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,968评论 6 482
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,601评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 153,220评论 0 344
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,416评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,425评论 5 374
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,144评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,432评论 3 401
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,088评论 0 261
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,586评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,028评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,137评论 1 334
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,783评论 4 324
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,343评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,333评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,559评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,595评论 2 355
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,901评论 2 345

推荐阅读更多精彩内容