SRT协议

news2025/4/1 5:27:54

        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();

    // 创建Socket
    SRTSOCKET 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.coloradmin.cn/o/2324083.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

K8S学习之基础五十一:k8s部署jenkins

k8s部署jenkins 创建nfs共享目录&#xff0c; mkdir -p /data/v2 echo /data/v2 *(rw,no_root_squash) > /etc/exports exportfs -arv创建pv、pvc vi pv.yaml apiVersion: v1 kind: PersistentVolume metadata:name: jenkins-k8s-pv spec:capacity:storage: 1GiaccessMod…

在 Mermaid 流程图里“驯服”quot;的魔法指南!!!

&#x1f409; 在 Mermaid 流程图里“驯服”"的魔法指南 在使用 Mermaid 画流程图时&#xff0c;是不是经常遇到想秀一波 &quot; 却被它“反杀”的情况&#xff1f;&#x1f3af; 今天就来教大家如何在这头代码野兽的嘴里&#xff0c;抢回我们的双引号实体编码&#…

GitHub美化个人主页3D图表显示配置操作

这个功能主要是用的这个开源仓库&#xff1a;https://github.com/yoshi389111/github-profile-3d-contrib 想看效果的话&#xff0c;我的个人主页&#xff1a;https://github.com/Sjj1024 开始操作 1.创建自己的github主页属性项目——跟你github用户名一致即可&#xff0c;…

HarmonyOS NEXT 鸿蒙中关系型数据库@ohos.data.relationalStore API 9+

核心API ohos.data.relationalStore API 9 数据库 数据库是存储和管理数据的系统 数据库&#xff08;Database&#xff09;是一个以特定方式组织、存储和管理数据的集合&#xff0c;通常用于支持各种应用程序和系统的运行。它不仅是存放数据的仓库&#xff0c;还通过一定的…

【JavaScript】JavaScript Promises实践指南

【JavaScript】JavaScript Promises实践指南 你了解JavaScript中的Promises吗&#xff1f;这是一个很多人一开始就放弃的主题&#xff0c;但我会尽量让它变得尽可能简单。 1. “Promise”到底是什么&#xff1f; “Promise”是异步编程中的一个基本概念&#xff0c;特别是在J…

git push的时候出现无法访问的解决

fatal: 无法访问 https://github.com/...&#xff1a;gnutls_handshake() failed: Error in the pull function. push的时候没有输入自己的github账号密码&#xff0c;为了解决每次push都要登录github这个问题&#xff0c;采用ssh密钥的方式认证&#xff0c;可以免去每次都输入…

为什么大模型在 OCR 任务上表现不佳?

编者按&#xff1a; 你是否曾经用最先进的大语言模型处理企业文档&#xff0c;却发现它把财务报表中的“$1,234.56”读成了“123456”&#xff1f;或者在处理医疗记录时&#xff0c;将“0.5mg”误读为“5mg”&#xff1f;对于依赖数据准确性的运营和采购团队来说&#xff0c;这…

HCIP(VLAN综合实验)

实验拓补图 实验分析 一、实验目的 掌握VLAN的创建和配置方法理解VLAN在局域网中的作用学习如何通过VLAN实现网络隔离和通信 二、实验环境 交换机&#xff08;SW1、SW2、SW3&#xff09;个人电脑&#xff08;PC1、PC2、PC3、PC4、PC5、PC6&#xff09;路由器&#xff08;R1…

每日算法-250328

记录今天学习和解决的LeetCode算法题。 92. 反转链表 II 题目 思路 本题要求反转链表中从 left 到 right 位置的节点。我们可以采用 头插法 的思路来反转指定区间的链表。 具体来说&#xff0c;我们首先定位到 left 位置节点的前一个节点 prev。然后&#xff0c;从 left 位置…

从 Word 到 HTML:使用 Aspose.Words 轻松实现 Word 文档的高保真转换

从 Word 到 HTML&#xff1a;使用 Aspose.Words 轻松实现 Word 文档的高保真转换 前言一、环境准备二、核心代码实现1. 将 Word 转换为 HTML 文件流2. 优化超链接样式 三、测试效果四、总结 前言 在日常开发中&#xff0c;我们经常需要将 Word 文档转换为 HTML&#xff0c;用于…

RSA 简介及 C# 和 js 实现【加密知多少系列_4】

〇、简介 谈及 RSA 加密算法&#xff0c;我们就需要先了解下这两个专业名词&#xff0c;对称加密和非对称加密。 对称加密&#xff1a;在同一密钥的加持下&#xff0c;发送方将未加密的原文&#xff0c;通过算法加密成密文&#xff1b;相对的接收方通过算法将密文解密出来原文…

机器学习——LightGBM

LightGBM(light gradient boosting machine&#xff0c;轻量梯度提升机)是对XGBoost进行改进的模型版本&#xff0c;其三者之间的演变关系为&#xff1a;GBDT-》XGBoost-》LightGBM&#xff0c;依次对性能进行优化&#xff0c;尽管XGBoost已经很高效了&#xff0c;但是仍然有缺…

故障识别 | 基于改进螂优化算法(MSADBO)优化变分模态提取(VME)结合稀疏最大谐波噪声比解卷积(SMHD)进行故障诊断识别,matlab代码

基于改进螂优化算法&#xff08;MSADBO&#xff09;优化变分模态提取&#xff08;VME&#xff09;结合稀疏最大谐波噪声比解卷积&#xff08;SMHD&#xff09;进行故障诊断识别 一、引言 1.1 机械故障诊断的背景和意义 在工业生产的宏大画卷中&#xff0c;机械设备的稳定运行…

[已解决]服务器CPU突然飙高98%----Java程序OOM问题 (2024.9.5)

目录 问题描述问题排查问题解决参考资料 问题描述 业主单位服务器自8月29日晚上21:00起CPU突然飙高至98%&#xff0c;内存爆满&#xff0c;一直到9月5日&#xff1a; 问题排查 ①执行 top 命令查看Java进程PID top②执行top -Hp PID 命令查看具体的线程情况 top -Hp 3058输入上…

Ai工作流工具有那些如Dify、coze扣子等以及他们是否开源

Dify &#xff08;https://difycloud.com/&#xff09; 核心定位&#xff1a;专业级 LLM 应用开发平台&#xff0c;支持复杂 AI 工作流构建与企业级管理。典型场景&#xff1a;企业智能客服、数据分析系统、复杂自动化流程构建等。适合需要深度定制、企业级管理和复杂 AI 逻辑…

Yolo_v8的安装测试

前言 如何安装Python版本的Yolo&#xff0c;有一段时间不用了&#xff0c;Yolo的版本也在不断地发展&#xff0c;所以重新安装了运行了一下&#xff0c;记录了下来&#xff0c;供参考。 一、搭建环境 1.1、创建Pycharm工程 首先创建好一个空白的工程&#xff0c;如下图&…

软件兼容性测试的矩阵爆炸问题有哪些解决方案

解决软件兼容性测试中的矩阵爆炸问题主要有优先级划分、组合测试方法、自动化测试技术等方案。其中&#xff0c;组合测试方法尤其有效。组合测试通过科学的组合算法&#xff0c;能够显著降低测试用例的数量&#xff0c;同时保持较高的测试覆盖率&#xff0c;例如正交实验设计&a…

嵌入式学习(32)-TTS语音模块SYN6288

一、概述 SYN6288 中文语音合成芯片是北京宇音天下科技有限公司于 2010年初推出的一款性/价比更高,效果更自然的一款中高端语音合成芯片。SYN6288 通过异步串口(UART)通讯方式&#xff0c;接收待合成的文本数据&#xff0c;实现文本到语音(或 TTS 语音)的转换。宇音天下于 2002…

从零到一:打造顶尖生成式AI应用的全流程实战

简介 生成式AI正以前所未有的速度改变我们的世界&#xff0c;从内容创作到智能客服&#xff0c;再到医疗诊断&#xff0c;它正在成为各行各业的核心驱动力。然而&#xff0c;构建一个高效、安全且负责任的生成式AI系统并非易事。本文将带你从零开始&#xff0c;逐步完成一个完整…

Windows 10更新失败解决方法

在我们使用 Windows 时的时候&#xff0c;很多时候遇到系统更新 重启之后却一直提示“我们无法完成更新&#xff0c;正在撤销更改” 这种情况非常烦人&#xff0c;但其实可以通过修改文件的方法解决&#xff0c;并且正常更新到最新版操作系统 01修改注册表 管理员身份运行注…