SRT协议

embedded/2025/4/2 5:52:19/

        SRT(Secure Reliable Transport)是一种开源的视频传输协议,专为高丢包、高延迟网络环境设计,结合了UDP的低延迟和TCP的可靠性,广泛应用于直播、远程制作、视频会议等场景。

  • 定位:SRT协议的官方C/C++实现库,由Haivision和社区维护,提供高可靠、低延迟的流媒体传输能力。

  • 核心功能

    • 支持SRT协议的全部特性(ARQ重传、FEC、AES加密、自适应码率)。

    • 跨平台(Windows/Linux/macOS),提供C API和C++封装。

    • 与FFmpeg、GStreamer等主流多媒体框架集成。

1. SRT的核心优势

特性描述
低延迟基于UDP,支持端到端延迟可控制在 100ms~500ms(可配置)。
抗丢包通过ARQ(自动重传请求)和FEC(前向纠错)恢复丢包,支持 30%+ 丢包率
安全性内置AES加密(128/256位),防止数据窃听。
自适应码率动态调整发送速率,避免网络拥塞。
多路复用支持单端口多流传输,降低资源占用。

2. SRT的工作原理

(1) ARQ(自动重传请求)
  • 丢包检测:接收端通过序列号检测丢包,发送NACK(丢包重传请求)。

  • 选择性重传:仅重传丢失的包,而非全部数据,减少带宽浪费。

  • 重传超时:可配置超时时间(默认250ms),超时后放弃重传,避免延迟累积。

(2) FEC(前向纠错)
  • 可选功能,在数据包中加入冗余信息,允许接收端直接恢复少量丢包(无需重传)。

(3) 自适应传输
  • 带宽探测:持续监测网络带宽,动态调整发送码率。

  • 延迟控制:通过缓冲区(Latency Buffer)平滑网络抖动,保持稳定延迟。

3. SRT的典型应用场景

场景配置建议
直播推流使用 SRT + FEC,码率自适应(如5Mbps动态调整),延迟设为1秒。
远程制作低延迟模式(200ms),启用AES加密,保证实时性和安全性。
跨国传输启用ARQ和FEC,设置冗余包比例10%~20%,对抗高丢包。
企业视频会议使用SRT多路复用,单端口传输多路视频,降低防火墙配置复杂度。

4. SRT vs. 其他协议

协议延迟可靠性适用场景
SRT高(ARQ+FEC)直播、远程制作、高丢包网络
RTMP中(TCP)传统直播推流
WebRTC极低中(部分丢包)实时通信、P2P场景
QUIC高(多路复用)HTTP/3流媒体

5. SRT的配置与使用

(1) 常用参数
参数说明示例值
latency端到端最大延迟(毫秒)1000
passphraseAES加密密钥(需16/24/32字符)MySecureKey123
fecFEC冗余配置(如rows:10,cols:5rows:10
maxbw最大发送带宽(Mbps)10
(2) 推流示例(FFmpeg)
# 推流端(Publisher)
ffmpeg -i input.mp4 -c:v libx264 -preset fast -f mpegts "srt://接收端IP:9000?latency=500&passphrase=MyKey"# 接收端(Subscriber)
ffplay "srt://0.0.0.0:9000?latency=500&passphrase=MyKey"
(3) 工具支持
  • srt-live-transmit:官方测试工具,用于中继或调试。

  • OBS Studio:支持SRT推流(设置→输出→选择SRT协议)。

  • Haivision Play Pro:SRT播放器,支持加密和低延迟模式。

6. libsrt库编译与配置

(1) 编译安装(Linux)
# 安装依赖
sudo apt-get install cmake tclsh pkg-config# 下载源码
git clone https://github.com/Haivision/srt.git
cd srt
./configure --prefix=/usr/local --enable-shared=ON
make -j4
sudo make install# 验证安装
srt-live-transmit --version
(2) Windows编译

1)使用CMake生成VS工程(比如:VS2019):

cmake -G "Visual Studio 16 2019" -A x64 ..

2)打开生成的.sln文件编译ALL_BUILD目标。

7. libsrt库使用

(1) 创建SRT Socket(C语言)
#include <srt/srt.h>int main() {// 初始化库srt_startup();// 创建SocketSRTSOCKET sock = srt_create_socket();if (sock == SRT_INVALID_SOCK) {fprintf(stderr, "srt_create_socket failed\n");return 1;}// 设置参数:延迟500ms,启用加密srt_setsockflag(sock, SRTO_LATENCY, "500", sizeof(int));srt_setsockflag(sock, SRTO_PASSPHRASE, "MySecretKey123", 13);// 绑定端口(接收端)struct sockaddr_in sa = {0};sa.sin_family = AF_INET;sa.sin_port = htons(9000);sa.sin_addr.s_addr = INADDR_ANY;srt_bind(sock, (struct sockaddr*)&sa, sizeof(sa));// 进入监听模式srt_listen(sock, 5);// 接收连接(省略事件循环)SRTSOCKET client = srt_accept(sock, NULL, NULL);// 数据传输...char buffer[1316];  // SRT最大有效载荷int len = srt_recvmsg(client, buffer, sizeof(buffer));// 清理srt_close(sock);srt_cleanup();return 0;
}
 (2) 发送数据
#include <srt/srt.h>
#include <iostream>int send_data(SRTSOCKET sock, const char* data, size_t len) {int ret = srt_sendmsg(sock, data, len, -1, 0);if (ret == SRT_ERROR) {std::cerr << "Send failed: " << srt_getlasterror_str() << std::endl;return -1;}return ret;  // 返回成功发送的字节数
}
(3)关键参数配置 
参数名(Flag)类型说明推荐值
SRTO_LATENCYint (ms)端到端最大允许延迟直播:1000~2000
SRTO_PASSPHRASEstringAES加密密钥(长度16/24/32字节)强制设置
SRTO_OHEADBWint (%)FEC冗余带宽占比丢包高时:20
SRTO_MAXBWint64最大发送带宽(bytes/sec)根据网络调整
SRTO_RCVSYNbool接收操作是否阻塞非阻塞:false
(4)FFmpeg编译支持libsrt
# 配置FFmpeg时加入--enable-libsrt
./configure --enable-libsrt --extra-ldflags=-lsrt

推流、播流

# 推流端
ffmpeg -i input.mp4 -c:v libx264 -preset fast -f mpegts 'srt://192.168.1.100:9000?latency=500&passphrase=MyKey'# 接收端
ffplay 'srt://0.0.0.0:9000?latency=500&passphrase=MyKey'
 (5)高级功能

   1)多路流复用

// 启用多路复用(需SRT v1.5+)
srt_setsockflag(sock, SRTO_STREAMID, "#!::r=live/stream1", 18);

   2)自适应码率控制

// 动态调整发送带宽(根据网络反馈)
int64_t available_bw = ...;  // 从网络探测获取
srt_setsockflag(sock, SRTO_MAXBW, &available_bw, sizeof(available_bw));

   3)日志启用

// 设置日志级别
srt_setloglevel(srt_logging::LogLevel::debug);// 自定义日志回调
srt_setloghandler(nullptr, [](void* p, int level, const char* file, int line, const char* area, const char* msg) {printf("[SRT] %s:%d %s\n", file, line, msg);
});

   4)关键统计信息

SRT_TRACEBSTATS stats;
srt_bstats(sock, &stats, 1);printf("丢包率: %.2f%%\n", (stats.pktLossTotal * 100.0) / stats.pktSentTotal);
printf("延迟: %d ms\n", stats.msRTT);

8. 调试与优化

  • 监控丢包率:通过srt-logsffmpeg日志查看丢包和重传统计。

  • 调整延迟缓冲区

    • 网络稳定时减少latency(如500ms→200ms)。

    • 高抖动时增大latency(如2000ms)。

  • 带宽自适应:设置maxbw为物理带宽的80%,留出冗余。

9. 注意事项

  1. 防火墙/NAT穿透:确保UDP端口开放(默认10000-65535),或使用SRT的Rendezvous模式。

  2. 加密密钥管理:定期更换passphrase,避免密钥泄露。

  3. 硬件加速:使用支持SRT的硬件编码器(如Haivision Makito X)降低CPU占用。


http://www.ppmy.cn/embedded/177339.html

相关文章

JavaScript时间戳的使用

1、什么是时间戳 在 JavaScript 中,时间戳(Timestamp)通常指自 1970 年 1 月 1 日 00:00:00 UTC(Unix 纪元)以来的毫秒数。时间戳(timestamp)是一个能够表示一份数据在某个特定时间点已经存在的、完整的、可验证的数据,通常是一个字符序列,唯一地标识某一刻的时间。它…

mathtype一些用法总结

1.一个是公式旁边加入||&#xff0c;一般使用键盘直接打入的会比较小&#xff0c;mathtype中的会好看很多&#xff0c;打开这个栏目&#xff0c;会看到有很多。 2.另外是带^符号&#xff0c;在字符上面带没有办法直接带&#xff0c;所以可以在mathtype中先加帽子&#xff0c;然…

使用HTML5和CSS3实现3D旋转相册效果

使用HTML5和CSS3实现3D旋转相册效果 这里写目录标题 使用HTML5和CSS3实现3D旋转相册效果项目介绍技术栈核心功能实现思路1. HTML结构2. CSS样式解析2.1 基础样式设置2.2 3D效果核心样式2.3 卡片样式 3. JavaScript交互实现3.1 旋转控制3.2 自动播放功能 技术要点总结项目亮点总…

Milvus Java SDK

Java&#xff08;8 或更高版本&#xff09; 安装步骤 1. 获取源码或依赖引入 Apache Maven <dependency><groupId>io.milvus</groupId><artifactId>milvus-sdk-java</artifactId><version>2.5.5</version> </dependency> …

【Python】编程50个经典操作

一、字符串操作 1、字符串反转 s "hello" print(s[::-1]) # olleh 2、字符串拼接 words ["python", "is", "awesome"] print(" ".join(words)) # python is awesome 3、字符串格式化&#xff08;f-string&#xff…

常⻅中间件漏洞--Tomcat

tomcat是⼀个开源⽽且免费的jsp服务器&#xff0c;默认端⼝ : 8080&#xff0c;属于轻量级应⽤服务器。它可以实现 JavaWeb程序的装载&#xff0c;是配置JSP&#xff08;Java Server Page&#xff09;和JAVA系统必备的⼀款环境。 1.CVE-2017-12615 Tomcat put⽅法任意⽂件写…

Ubuntu服务器挂载时遇到文件系统错误怎么办

在Ubuntu服务器上挂载分区时&#xff0c;如果遇到文件系统错误&#xff0c;通常可能是由于磁盘损坏、文件系统损坏、不正确的卸载等原因造成的。以下是详细的排查与修复步骤&#xff1a; 一、查看错误信息 首先&#xff0c;尝试手动挂载并观察具体错误&#xff1a; sudo mount …

MacOS bashzsh 命令行自动推荐补全工具

bash 推荐 之前使用的 Fig【已经不在维护&#xff0c;需要升级成Amazon Q】 Amazon Q 安装教程 $ brew install amazon-q > Auto-updating Homebrew... Adjust how often this is run with HOMEBREW_AUTO_UPDATE_SECS or disable with HOMEBREW_NO_AUTO_UPDATE. Hide th…