RTP over TCP 模式

RTP over TCP 模式概述

RTP over TCP 指的是将RTP数据包封装在TCP连接中进行传输,而不是使用传统的基于UDP的传输方式。

与UDP模式对比

特性 RTP over TCP RTP over UDP
端口数量 仅需 1 个 TCP 端口(默认 554) 每路流需 2 个 UDP 端口(数据+控制)
可靠性 依赖 TCP 重传机制,数据无丢失 可能丢包,影响实时性
防火墙兼容性 易穿透(常用端口 554) 需开放多个端口,易被拦截
延迟 较高(重传机制引入延迟) 较低(无连接、无重传)
适用场景 高丢包网络(如互联网)、防火墙环境 低延迟需求(局域网、专网)

工作原理

在RTSP的RTP over TCP模式下,RTP和RTCP数据被"隧道化"到RTSP控制连接中,通常使用基于分隔符的帧间发送(Interleaved Mode)。具体流程如下:

  1. 建立RTSP连接:客户端与服务器之间首先建立一个RTSP的TCP连接,通常是在端口554上。

  2. SETUP 阶段协商
    客户端在 SETUP 请求中指定传输方式为 TCP,并分配交织通道号:

    http 复制代码
    Transport: RTP/AVP/TCP;interleaved=0-1
  • 0-1 表示视频流:0 为 RTP 数据通道(偶数),1 为 RTCP 控制通道(奇数)。
  • 音频流通常分配 2-3 通道。
  1. 发送RTP/RTCP数据:在同一个TCP连接上,RTP和RTCP数据通过特定的通道(通常是通过RTSP"interleaving"机制,即在RTSP消息中嵌入RTP数据)进行传输。每个RTP/RTCP包前面会有一个标识符(通常是"$"符号后跟通道号),以区分不同类型的数据。
  2. 数据封装格式
    每个 RTP/RTCP 包添加 4 字节头部,结构如下:
字段 长度 说明
Magic Number 1 字节 固定值 0x24(ASCII 字符 $),用于标识 RTP/RTCP 数据包。
Channel Number 1 字节 通道号(如 0 代表 RTP 视频数据,1 代表 RTCP 视频控制)。
Embedded Data Len 2 字节 后续 RTP/RTCP 数据包的长度(网络字节序)。
Data N 字节 实际的 RTP 或 RTCP 数据包

RTCP SR数据包封装:

视频RTP包封装:

参考资源

  1. RFC 4571
    Interleaved RTP over TCP

  2. RFC 4571
    Embedded (Interleaved) Binary Data

  3. RTP/AVP & RTP/AVP/TCP

相关推荐
156082072195 小时前
基于7VX690T FPGA实现万兆TCP/IP资源和性能测试
网络协议·tcp/ip·fpga开发
踏浪无痕8 小时前
线上偶发 502 排查:用 Netty 成功复现 KeepAlive 时间窗口案例实战(附完整源码)
运维·网络协议
北京耐用通信8 小时前
告别“牵一发而动全身”:耐达讯自动化Profibus PA分线器为石化流量计网络构筑安全屏障
人工智能·网络协议·安全·自动化·信息与通信
Sinowintop8 小时前
易连EDI-EasyLink无缝集成之消息队列Kafka
分布式·网络协议·kafka·集成·国产化·as2·国产edi
阿巴~阿巴~16 小时前
自定义协议设计与实践:从协议必要性到JSON流式处理
服务器·网络·网络协议·json·操作系统·自定义协议
jinxinyuuuus1 天前
GTA 风格 AI 生成器:跨IP融合中的“视觉语义冲突”与风格适配损失
人工智能·网络协议
嵌入式-小王1 天前
每天掌握一个网络协议----ICMP
网络·网络协议·ping
Awkwardx1 天前
Linux网络编程—应用层协议HTTP
网络·网络协议·http
Running_slave1 天前
你应该了解的TCP滑窗
前端·网络协议·tcp/ip
无证驾驶梁嗖嗖1 天前
无需公网 IP,MongoDB 也能跨环境访问?试试这个实用方案
网络协议·tcp/ip·mongodb