流媒体传输 - RTMP 协议报文分析

本文深入探讨RTMP协议的Chunk Header,包括Chunk Basic Header、Message Header和Extended Timestamp。详细阐述了各个字段的作用,如fmt、timestamp delta、message length等,并介绍了Chunk Data的不同类型,如协议控制消息、用户控制消息和命令消息,揭示了RTMP协议中数据传输的细节。
摘要由CSDN通过智能技术生成

握手之后,连接开始对一个或多个 chunk stream 进行合并。创建的每个块都有一个唯一 id 对其进行关联,这个 id 叫做 chunk stream id。这些块通过网络进行传输。传递时,每个块必须被完全发送才可以发送下一块。在接收端,这些块被根据 chunk stream id 被组装成消息。

每个块包含一个头和数据体。块头包含三个部分:

+--------------+----------------+--------------------+--------------+
| Basic Header | Message Header | Extended Timestamp |  Chunk Data  |
+--------------+----------------+--------------------+--------------+
|<------------------- Chunk Header ----------------->|
                            Chunk Format

Chunk Header

chunk Header 包括 Basic HeaderMessage HeaderExtended Timestamp 三部分。

  • Basic Header (1 - 3 bits):这个字段对 chunk stream id 和块类型进行编码。块类型决定了消息头的编码格式。该字段长度完全取决于 chunk stream id,因为 chunk stream id 是一个可变长度的字段。

  • Message Header (0 / 3 / 7 / 11bits):这一字段对正在发送的消息 (不管是整个消息,还是只是一小部分) 的信息进行编码。这一字段的长度可以使用块头中定义的块类型进行决定。

  • Extended Timestamp (0 / 4 bytes):这一字段是否出现取决于块消息头中的 timestamp 或者 timestamp delta 字段。更多信息参考

Chunk Basic Header

chunk Basic Headerchunk stream id 和块类型 (由下图中的 fmt 字段表示) 进行编码。chunk Basic Header 字段可能会有 12 或者 3 个字节,取决于 chunk stream id

一个 RTMP 实现应该使用能够容纳这个 id 的最小的容量进行表示。

RTMP 协议最多支持 65597 个流,chunk stream id 范围 3 - 65599id 012 被保留。

  • 0 值表示二字节形式,并且 chunk stream id 范围 64 - 319

       0                   1
       0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |fmt|     0     |   cs id - 64  |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
            Chunk Basic Header 2
  • 1 值表示三字节形式,并且 chunk stream id 范围为 64 - 65599

       0                   1                   2
       0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |fmt|     1     |           cs id - 64          |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
                  chunk Basic Header 3
  • 3 - 63 范围内的值表示整个流 chunk stream id

        0 1 2 3 4 5 6 7
       +-+-+-+-+-+-+-+-+
       |fmt|   cs id   |
       +-+-+-+-+-+-+-+-+
      chunk Basic Header 1
  • 带有 2 值的 chunk stream id 被保留,用于下层协议控制消息和命令。

协议中字段代表的意义如下:

  • fmt (2bits):这一字段指示 chunk Message Header 使用的四种格式之一。

  • cs id (6bits):这一字段包含有 chunk stream id,值的范围是 2 - 63。值 01 用于指示这一字段是 2 或 3 字节版本。

  • cs id - 64 (8/16bits):这一字段包含了 chunk stream id 减掉 64 后的值。例如,chunk stream id365 时会在 cs id 中会以一个 1cs id - 64 中的一个 16 位 的 301 进行表示。

    chunk stream id 64 - 319 可以使用 2-byte 或者 3-byte 的形式在头中表示。

Message Header

【学习地址】:FFmpeg/WebRTC/RTMP/NDK/Android音视频流媒体高级开发
【文章福利】:免费领取更多音视频学习资料包、大厂面试题、技术视频和学习路线图,资料包括(C/C++,Linux,FFmpeg webRTC rtmp hls rtsp ffplay srs 等等)有需要的可以点击1079654574加群领取哦~

  

  • Type 0:块头的长度是 11bits。这一类型必须用在 chunk stream 的起始位置,和流 timestamp 重来的时候 (比如,重置)。

      0                   1                   2                   3
      0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值