RTP协议

RTP协议


目录

  1. RTP报⽂格式
  2. SSRC和CSRS解释

1. RTP报⽂格式

  1. RTP报⽂由两部分组成:报头和有效载荷。RTP报头格式如下图所示,其中:

    1. V:RTP协议的版本号,占2位,当前协议版本号为2。
    2. P:填充标志,占1位,如果P=1,则在该报⽂的尾部填充⼀个或多个额外的⼋位组,它们不是有效载荷的⼀部分。
    3. X:扩展标志,占1位,如果X=1,则在RTP报头后跟有⼀个扩展报头。
    4. CC:CSRC计数器,占4位,指示CSRC 标识符的个数。
    5. M: 标记,占1位,不同的有效载荷有不同的含义,对于视频,标记⼀帧的结束;对于⾳频,标记帧的开始。
    6. PT: 有效载荷类型,占7位,⽤于说明RTP报⽂中有效载荷的类型,如GSM⾳频、JPEM图像等。
    7. 序列号:占16位,⽤于标识发送者所发送的RTP报⽂的序列号,每发送⼀个报⽂,序列号增1。接收者通过序列号来检测报⽂丢失情况,重新排序报⽂,恢复数据。
    8. 时戳(Timestamp):占32位,时戳反映了该RTP报⽂的第⼀个⼋位组的采样时刻。接收者使⽤时戳来计算延迟和延迟抖动,并进⾏同步控制。
    9. 同步信源(SSRC)标识符:占32位,⽤于标识同步信源。该标识符是随机选择的,参加同⼀视频会议的两个同步信源不能有相同的SSRC
  2. 上面总共12个字节

  3. 特约信源(CSRC)标识符:每个CSRC标识符占32位,可以有0~15个。每个CSRC标识了包含在该RTP报⽂有效载荷中的所有特约信源。

在这里插入图片描述

  1. 抓包展示
    在这里插入图片描述

  2. 对应结构体

typedef struct _rtp_header{
    uint32_t v:2; /*
    uint32_t p:1; /*
    uint32_t x:1; /*
    uint32_t cc:4; /*
    uint32_t m:1; /*
    uint32_t pt:7; /*
    uint32_t seq:16; /*
    uint32_t timestamp; /*
    uint32_t ssrc; /*
} rtp_header_t;

2. SSRC和CSRS解释

  1. 同步信源是指产⽣媒体流的信源,例如⻨克⻛、摄像机、RTP混合器等。它通过RTP报头中的⼀个32位数字SSRC标识符来标识,⽽不依赖于⽹络地址,接收者将根据SSRC标识符来区分不同的信源,进⾏RTP报⽂的分组。
  2. 特约信源是指当混合器接收到⼀个或多个同步信源的RTP报⽂后,经过混合处理产⽣⼀个新的组合RTP报⽂,并把混合器作为组合RTP报⽂的SSRC,⽽将原来所有的SSRC都作为CSRC传送给接收者,使接收者知道组成组合报⽂的各个SSRC。
  3. 在发送端,上层应⽤程序以分组形式将编码后的媒体数据传给RTP通信模块,作为RTP报⽂的有效载荷,RTP通信模块将根据上层应⽤提供的参数在有效载荷前添加RTP报头,形成RTP报⽂,通过Socket接⼝选择UDP协议发送出去。
  4. 在接收端,RTP通信模块通过Socket接⼝接收到RTP报⽂后,将RTP报头分离出来作相应处理,再将RTP报⽂的有效载荷作为数据分组传递给上层应⽤。
  5. 同步信源(SSRC)标识符:占32位,⽤于标识同步信源。该标识符是随机选择的,参加同⼀视频会议的两个同步信源不能有相同的SSRC。
  6. 特约信源(CSRC)标识符:每个CSRC标识符占32位,可以有0~15个。每个CSRC标识了包含在该RTP报⽂有效载荷中的所有特约信源。
  7. 这⾥的同步信源是指产⽣媒体流的信源,例如⻨克⻛、摄像机、RTP混合器等;它通过RTP报头中的⼀个32位数字SSRC标识符来标识,⽽不依赖于⽹络地址,接收者将根据SSRC标识符来区分不同的信源,进⾏RTP报⽂的分组。
  8. 特约信源是指当混合器接收到⼀个或多个同步信源的RTP报⽂后,经过混合处理产⽣⼀个新的组合RTP报⽂,并把混合器作为组合RTP报⽂的 SSRC,⽽将原来所有的SSRC都作为CSRC传送给接收者,使接收者知道组成组合报⽂的各个SSRC。
  9. 若⼀个RTP包流的源,对由RTP混频器⽣成的组合流起了作⽤,则它就是⼀个作⽤源。对特定包的⽣成起作⽤的源,其SSRC标识符组成的列表,被混频器插⼊到包的RTP报头中。这个列表叫做CSRC表。
  10. ⽤图表示⼤概是这样:
    在这里插入图片描述
  11. 例如,有三个信号源各发出⼀路rtp流,RTP1携带的SSRC是SSRC1,RTP2携带的SSRC是SSRC2,RTP3携带SSRC3,这三路RTP流到达混合器时,混合器会将这三路流混合成⼀路流发出去,它会把这三路流的SSRC记录下来,形成⼀个列表,叫CSRC表,在发送的混合RTP流中,SSRC域填充的字段是混合器本身的SSRC4,⽽CSRC字段则会根据该包的负载的源来填⼊。
  12. 例如当前的RTP包的负载是来⾃SSRC1的,那么在当前RTP包的CSRC字段填⼊SSRC1。这样接收者就可以根据CSRC来区分不同的信源;⼀般的,混合的RTP流中,每隔⼀段时间,就会有⼀个RTP报⽂包含了完整的CSRC表。例如在发送混合流时的第⼀个RTP包,它的CSRC域把CSRC表都填⼊,此时该包的负载可能是⽆意义或者并不是媒体流;此后的RTP报⽂中则根据负载的来源来填⼊CSRC域。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值