当前位置: 首页 > article >正文

SpringBoot+Vue+FFmpeg+Nginx:构建跨平台RTSP视频流低延迟播放方案

1. 为什么需要跨平台RTSP视频流方案RTSP协议作为监控摄像头、网络摄像机等设备的通用传输协议在实际项目中经常遇到浏览器兼容性问题。主流浏览器如Chrome、Firefox早已不再支持直接播放RTSP流这给需要网页展示监控画面的项目带来了巨大挑战。我在智慧园区项目中就遇到过这个痛点客户要求在大屏展示20路摄像头画面但前端工程师发现浏览器根本无法直接播放RTSP。经过多次技术验证最终选择了FFmpegNginx的转码方案将RTSP转为HTTP-FLV协议实现了所有现代浏览器的无缝支持。这个方案的核心优势在于跨平台兼容Windows/Linux服务器均可部署低延迟实测延迟控制在1秒以内高可用Nginx作为中间层具备负载均衡能力扩展性强支持动态增减视频源2. 环境准备与工具安装2.1 FFmpeg安装指南FFmpeg是整个方案的核心转码工具安装时需要注意版本兼容性。建议使用4.3以上版本以获得更好的H.264编码支持。Windows环境安装从官网下载静态编译版本解压到C:\ffmpeg目录添加bin目录到系统PATHsetx /M PATH %PATH%;C:\ffmpeg\bin验证安装ffmpeg -versionLinux环境安装以CentOS为例yum install epel-release yum install ffmpeg ffmpeg-devel2.2 Nginx与RTMP模块编译Nginx需要编译安装nginx-http-flv-module模块才能支持FLV直播流# 安装依赖 yum -y install gcc pcre pcre-devel zlib zlib-devel openssl openssl-devel # 下载源码 wget http://nginx.org/download/nginx-1.20.1.tar.gz git clone https://github.com/winshining/nginx-http-flv-module.git # 编译安装 tar -zxvf nginx-1.20.1.tar.gz cd nginx-1.20.1 ./configure --add-module../nginx-http-flv-module make make install3. 服务端实现方案3.1 SpringBoot命令调用封装通过Java调用FFmpeg需要处理不同操作系统的命令差异。我封装了一个通用工具类public class FFmpegExecutor { public static void startStream(String rtspUrl, String rtmpUrl) { String os System.getProperty(os.name).toLowerCase(); String command; if (os.contains(win)) { command String.format(ffmpeg -rtsp_transport tcp -i \%s\ -c:v libx264 -preset ultrafast -tune zerolatency -c:a aac -f flv \%s\, rtspUrl, rtmpUrl); } else { command String.format(ffmpeg -f rtsp -rtsp_transport tcp -i %s -codec copy -f flv %s, rtspUrl, rtmpUrl); } try { Runtime.getRuntime().exec(command); } catch (IOException e) { e.printStackTrace(); } } }3.2 Nginx流媒体服务器配置关键配置在nginx.conf中添加RTMP和HTTP-FLV支持rtmp { server { listen 1935; chunk_size 4096; application live { live on; record off; } } } http { server { listen 8080; location /live { flv_live on; add_header Access-Control-Allow-Origin *; } } }4. 前端低延迟播放实现4.1 Vue集成flv.js安装flv.js依赖npm install flv.js --save视频播放组件实现template video refvideoPlayer controls muted autoplay/video /template script import flvjs from flv.js; export default { props: [streamUrl], mounted() { if (flvjs.isSupported()) { this.player flvjs.createPlayer({ type: flv, url: this.streamUrl, isLive: true, stashInitialSize: 128 }); this.player.attachMediaElement(this.$refs.videoPlayer); this.player.load(); this.player.play(); } }, beforeDestroy() { this.player?.destroy(); } } /script4.2 性能优化技巧通过实际项目验证以下参数能显著降低延迟设置-preset ultrafast -tune zerolatency编码参数flv.js配置stashInitialSize: 128启用TCP传输-rtsp_transport tcp关闭音频流-an参数5. 全链路调试与问题排查常见问题及解决方案问题1Nginx接收不到流检查防火墙是否开放1935端口验证FFmpeg命令是否执行成功查看Nginx错误日志logs/error.log问题2前端播放卡顿降低视频分辨率-vf scale1280:-1调整关键帧间隔-g 50使用硬件加速如果支持-hwaccel cuvid问题3高并发场景崩溃增加Nginx worker进程数配置RTMP的out_queue参数考虑使用集群部署方案6. 进阶应用场景6.1 多路视频流管理通过动态生成application名称实现多路流隔离String appName stream_ cameraId; String rtmpUrl rtmp://nginx-server:1935/ appName /room;6.2 移动端适配方案针对移动端网络特点优化参数ffmpeg -rtsp_transport tcp -i rtsp://... -c:v libx264 -profile:v baseline -level 3.0 -preset ultrafast -tune zerolatency -vf scale640:360 -f flv rtmp://...6.3 安全加固措施配置Nginx鉴权模块启用HTTPS加密传输实现IP白名单限制7. 部署方案对比部署方式优点缺点物理机部署性能最优维护成本高Docker容器化快速部署网络配置复杂云服务器弹性扩展带宽成本高边缘计算节点降低中心节点压力需要分布式管理8. 监控与维护建议添加以下监控指标FFmpeg进程存活状态单路流CPU占用率端到端延迟时间内存使用情况可以通过SpringBoot Actuator暴露健康检查接口GetMapping(/stream/health) public ResponseEntity? checkStreamHealth() { // 实现健康检查逻辑 }9. 项目实战经验在智慧工地项目中我们遇到阴雨天摄像头断流问题。最终发现是RTSP的TCP传输缓冲区不足导致通过调整以下参数解决-rtsp_transport tcp -buffer_size 1024000另一个坑是Nginx的worker连接数限制在高并发场景下需要调整events { worker_connections 10240; }10. 技术方案对比与WebRTC方案相比本方案的优势在于对老旧摄像头兼容性更好服务器资源消耗更低实现复杂度更小支持更多并发流而与HLS方案相比本方案的延迟优势明显实测可以控制在500ms以内满足绝大多数实时监控场景的需求。

相关文章:

SpringBoot+Vue+FFmpeg+Nginx:构建跨平台RTSP视频流低延迟播放方案

1. 为什么需要跨平台RTSP视频流方案 RTSP协议作为监控摄像头、网络摄像机等设备的通用传输协议,在实际项目中经常遇到浏览器兼容性问题。主流浏览器如Chrome、Firefox早已不再支持直接播放RTSP流,这给需要网页展示监控画面的项目带来了巨大挑战。 我在智…...

从游戏物理引擎到导弹模拟:用Unity/C++理解刚体动力学与运动学

从游戏物理引擎到导弹模拟:用Unity/C理解刚体动力学与运动学 在游戏开发中,我们经常需要处理物体的运动——从简单的跳跃到复杂的飞行模拟。Unity的Rigidbody组件或Unreal Engine的物理系统背后,隐藏着一套与导弹运动模型惊人相似的数学原理…...

Windows Cleaner:完全免费的C盘清理神器,3步解决磁盘空间不足问题

Windows Cleaner:完全免费的C盘清理神器,3步解决磁盘空间不足问题 【免费下载链接】WindowsCleaner Windows Cleaner——专治C盘爆红及各种不服! 项目地址: https://gitcode.com/gh_mirrors/wi/WindowsCleaner 你的Windows电脑是否经常…...

Python装饰器高级用法与元类编程在框架开发中的设计模式

Python装饰器与元类编程作为Python语言的高级特性,在框架开发中扮演着至关重要的角色。它们不仅能够简化代码结构,还能实现灵活的设计模式,提升框架的可扩展性和可维护性。本文将深入探讨装饰器的高级用法与元类编程在框架设计中的巧妙结合&a…...

如何在Windows中轻松实现DLL注入:Xenos工具完全指南

如何在Windows中轻松实现DLL注入:Xenos工具完全指南 【免费下载链接】Xenos Windows dll injector 项目地址: https://gitcode.com/gh_mirrors/xe/Xenos 想要在Windows系统中进行DLL注入却苦于复杂的技术门槛?Xenos作为一款专业的Windows DLL注入…...

AGV小车导航新选择:手把手教你配置倍加福PGV100R视觉引导传感器

AGV小车导航新选择:手把手教你配置倍加福PGV100R视觉引导传感器 在工业自动化领域,AGV(自动导引车)的导航精度直接决定了物流效率与系统可靠性。传统磁条导航虽成熟稳定,但缺乏灵活性;激光导航成本高昂且对…...

逆向踩坑实录:修改il2cpp.so时,为什么你的游戏会闪退?

逆向工程实战:深度解析il2cpp.so修改中的崩溃陷阱 每次看到游戏界面突然消失,那种挫败感就像打了一下午的存档突然消失。特别是当你按照教程一步步操作,最后点击运行时却只换来闪退的黑屏。这不是因为你不够聪明,而是因为逆向工程…...

IMX6ULL实战:从零构建LVGL嵌入式GUI

1. 环境准备与源码获取 第一次接触IMX6ULL和LVGL的朋友可能会觉得有点懵,其实只要跟着步骤走,移植过程并不复杂。我去年在做一个工业HMI项目时就用这套组合,实测下来稳定性很不错。先说说需要准备的东西: 开发环境方面&#xff0c…...

ViGEmBus:如何让Windows系统完美识别虚拟游戏手柄?

ViGEmBus:如何让Windows系统完美识别虚拟游戏手柄? 【免费下载链接】ViGEmBus Windows kernel-mode driver emulating well-known USB game controllers. 项目地址: https://gitcode.com/gh_mirrors/vi/ViGEmBus 你是否曾经遇到过这样的困扰&…...

用Lottie动画和LeanCloud,给你的React Native登录页加点‘魔法’(附完整代码)

用Lottie动画和LeanCloud打造React Native登录页的视觉魔法 在移动应用的世界里,第一印象决定一切。一个枯燥的登录页面可能会让用户对你的应用产生负面印象,而一个精心设计的交互体验则能瞬间提升品牌形象。作为React Native开发者,我们拥有…...

FortiGate DDNS进阶玩法:一条CLI命令实现多WAN口绑定不同域名,远程管理效率翻倍

FortiGate多WAN口DDNS深度配置指南:CLI实现精细化域名管理 当企业网络架构需要同时管理多条宽带线路时,传统GUI界面往往难以满足高阶需求。本文将带您深入FortiGate防火墙的CLI配置层,实现多WAN口绑定独立DDNS域名的进阶操作方案。 1. 多WA…...

【逆向实战】从算法到驱动:剖析学生机房管理助手7.8的进程隐藏与设备管控机制

1. 学生机房管理助手7.8逆向分析实战 记得第一次在学生机房看到那个熟悉的蓝色图标时,我就知道又要和这个"老朋友"斗智斗勇了。学生机房管理助手7.8版本相比之前的7.5版本,最明显的变化就是进程名随机化算法的调整。用dnSpy反编译脱壳后的mai…...

终极免费手机号码定位工具:一键查询电话号码地理位置

终极免费手机号码定位工具:一键查询电话号码地理位置 【免费下载链接】location-to-phone-number This a project to search a location of a specified phone number, and locate the map to the phone number location. 项目地址: https://gitcode.com/gh_mirro…...

终极指南:如何用G-Helper替代华硕Armoury Crate提升笔记本性能

终极指南:如何用G-Helper替代华硕Armoury Crate提升笔记本性能 【免费下载链接】g-helper Lightweight, open-source control tool for ASUS laptops and ROG Ally. Manage performance modes, fans, GPU, battery, and RGB lighting across Zephyrus, Flow, TUF, S…...

【MQTT安全实践】从零构建用户密码认证体系

1. 为什么物联网项目必须重视MQTT认证? 刚接触物联网开发时,很多开发者容易犯一个错误——直接使用未加密的MQTT默认配置。去年我参与审计的一个智能家居项目就因此吃了大亏:攻击者通过未加密的MQTT通道批量获取了上千个家庭的温湿度数据。这…...

mjpg-streamer进阶玩法:除了看监控,还能怎么用?实现拍照、RTSP推流与API调用

mjpg-streamer进阶玩法:解锁监控之外的无限可能 在智能家居和物联网设备遍地开花的今天,mjpg-streamer早已不再是简单的监控工具。这款轻量级开源软件凭借其高效的M-JPEG流处理能力,正在各种嵌入式场景中焕发新生。本文将带你探索三个鲜为人…...

CK2DLL终极指南:5分钟解决《十字军之王2》中文乱码问题

CK2DLL终极指南:5分钟解决《十字军之王2》中文乱码问题 【免费下载链接】CK2dll Crusader Kings II double byte patch /production : 3.3.4 /dev : 3.3.4 项目地址: https://gitcode.com/gh_mirrors/ck/CK2dll 你是否曾经在《十字军之王2》中创建了一个充满…...

保姆级教程:在全志A40i的Linux 3.10内核上配置RTL8188FU WiFi并测试网速

全志A40i嵌入式系统RTL8188FU无线网卡深度配置与性能调优指南 当你在全志A40i平台上第一次插入那块小小的USB无线网卡时,可能不会想到这个看似简单的动作背后隐藏着多少技术细节。作为一款广泛应用于工业控制、智能家居等领域的嵌入式处理器,全志A40i搭…...

树莓派5到手后第一件事:用Pi Imager v1.8.5烧录Raspberry Pi OS Bookworm的完整流程与隐藏功能

树莓派5到手后第一件事:用Pi Imager v1.8.5烧录Raspberry Pi OS Bookworm的完整流程与隐藏功能 树莓派5的发布让开发者们再次兴奋起来——更快的CPU、更强的GPU、更高的内存带宽,这些硬件升级意味着更流畅的多任务处理和更复杂的项目可能性。但无论硬件…...

Windows蓝牙通话实战:虚拟声卡驱动选型与配置全解析

1. 为什么需要虚拟声卡? 很多朋友在用Windows电脑接蓝牙耳机打电话时,可能会遇到一个尴尬的情况:明明耳机能听音乐,但就是没法通话。这其实是因为蓝牙协议中,音乐播放(A2DP)和语音通话&#xf…...

从Pytorch迁移到Jittor:在Windows上安装后,如何快速验证并跑通第一个模型(如ResNet50)

从PyTorch迁移到Jittor:Windows环境下的快速验证与模型实战指南 当你第一次在Windows上成功安装Jittor后,那种"然后呢?"的迷茫感我深有体会。作为从PyTorch转战Jittor的实践者,我将带你跳过那些官方文档没明说的坑&…...

ccmusic-database/music_genre实战教程:与FFmpeg流水线集成实现URL直传音频自动识别

ccmusic-database/music_genre实战教程:与FFmpeg流水线集成实现URL直传音频自动识别 1. 引言:从手动上传到自动化识别 想象一下,你正在开发一个音乐流媒体平台的后台,每天有成千上万首新歌需要自动打上流派标签。如果让编辑一首…...

go-zero中间件链与错误处理机制

go-zero中间件链与错误处理机制 一、中间件在 go-zero 中的定位 1.1 什么是中间件链 中间件(Middleware)是一种在请求到达业务逻辑之前、或响应返回客户端之前,执行横切关注点的机制。在 go-zero 中,中间件以「洋葱模型」组织&…...

别再暴力匹配了!用DBoW2词袋模型5分钟搞定ORB-SLAM2回环检测

从暴力匹配到高效检索:DBoW2词袋模型在ORB-SLAM2回环检测中的实战优化 当你在Jetson Nano上运行ORB-SLAM2时,是否经历过回环检测模块成为整个系统性能瓶颈的困扰?传统暴力匹配方法在面对数万张历史关键帧时,其O(N)的时间复杂度足以…...

go-zero RESTful API的proto定义规范

go-zero RESTful API的proto定义规范 一、proto 文件在 go-zero 生态中的角色 1.1 从 API 定义到 Go 代码的完整链路 在 go-zero 的 RPC 服务体系中,.proto 文件是唯一的「事实来源」(Single Source of Truth)。它不仅定义了服务接口、请求/响…...

物联网(IoT)应用开发:Phi-4-mini-reasoning推理设备数据流与协议转换

物联网(IoT)应用开发:Phi-4-mini-reasoning推理设备数据流与协议转换 1. 智能家居场景中的异构数据挑战 走进一个典型的智能家居环境,你会发现各种设备都在产生数据:温湿度传感器每隔30秒上报一次读数,智…...

手机号码定位终极指南:3分钟学会快速免费查询地理位置

手机号码定位终极指南:3分钟学会快速免费查询地理位置 【免费下载链接】location-to-phone-number This a project to search a location of a specified phone number, and locate the map to the phone number location. 项目地址: https://gitcode.com/gh_mirr…...

告别轮询!用Java-WebSocket库在Android上5分钟搞定WebSocket实时通信

告别轮询!用Java-WebSocket库在Android上5分钟搞定WebSocket实时通信 在移动应用开发中,实时数据同步一直是个棘手的问题。想象一下这样的场景:用户A发送了一条消息,用户B需要等待几秒甚至更久才能收到;股票行情数据延…...

深度学习环境搭建不再难:TensorFlow-v2.9镜像一键部署教程

深度学习环境搭建不再难:TensorFlow-v2.9镜像一键部署教程 还在为搭建TensorFlow环境而头疼吗?驱动版本冲突、Python环境混乱、依赖库安装失败……这些问题几乎成了每个AI开发者入门的“必修课”。但今天,我要告诉你一个好消息:这…...

Linux终端实战:从零构建命令行五子棋(双人对决)

1. 为什么要在终端写五子棋? 第一次在Linux终端里写五子棋时,我也觉得这想法挺奇怪的——放着那么多图形界面不用,干嘛非要跟黑底白字的命令行较劲?但真正动手后才发现,这个项目简直是Linux环境编程的完美练手项目。 用…...