握手之后,连接开始对一个或多个 chunk stream 进行合并。创建的每个块都有一个唯一 id 对其进行关联,这个 id 叫做 chunk stream id。这些块通过网络进行传输。传递时,每个块必须被完全发送才可以发送下一块。在接收端,这些块被根据 chunk stream id 被组装成消息。
每个块包含一个头和数据体。块头包含三个部分:
- +--------------+----------------+--------------------+--------------+
- | Basic Header | Message Header | Extended Timestamp | Chunk Data |
- +--------------+----------------+--------------------+--------------+
- |<------------------- Chunk Header ----------------->|
- Chunk Format
chunk Header 包括 Basic Header、Message Header、Extended 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 stream id 和块类型 (由下图中的 fmt 字段表示) 进行编码。chunk Basic Header 字段可能会有 1,2 或者 3 个字节,取决于 chunk stream id。
一个 RTMP 实现应该使用能够容纳这个 id 的最小的容量进行表示。
RTMP 协议最多支持 65597 个流,chunk stream id 范围 3 - 65599。id 0、1、2 被保留。
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。值 0 或 1 用于指示这一字段是 2 或 3 字节版本。
cs id - 64 (8/16bits):这一字段包含了 chunk stream id 减掉 64 后的值。例如,chunk stream id 为 365 时会在 cs id 中会以一个 1 和 cs id - 64 中的一个 16 位 的 301 进行表示。
chunk stream id64 - 319可以使用 2-byte 或者 3-byte 的形式在头中表示。
【学习地址】: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
- +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
- | timestamp