ffmpeg+nginx实现rtsp协议摄像头web端播放

ffmpeg+nginx实现rtsp协议摄像头web端播放

环境准备

  • nginx(需要安装rtmp模块)
  • ffmpeg 6.0
  • vlc播放器(本地播放验证)

这些资源已经上传需要的可以自己下载,这个压缩包里的nginx已经安装好所需模块,解压即可使用
下载地址

准备nginx环境

添加rtmp模块

bash 复制代码
# 注意这个和http模块同级
rtmp {
    server {
        listen 1935;  # 监听端口 1935,用于 RTMP 数据流传输
        chunk_size 4000;  # 数据传输分块大小
        
        application live {  # 定义RTMP的路径名
             live on;  # 开启 RTMP 直播功能
             hls on;  # 开启 HLS 功能
             hls_path html/hls;  # HLS 分片文件存储路径
             hls_fragment 2s;  # 每个 HLS 分片的时长为 2 秒。
             hls_playlist_length 6s;  # HLS 播放列表长度为 6 秒
        }
    }
}

添加hls转发

bash 复制代码
         # 这个在server模块里面
         location /hls {
        	#配置MIME 类型
        	types {
        		application/vnd.apple.mpegurl m3u8;
        		video/mp2t ts;
        	}
        	#指定请求路径对应的文件路径(HLS 分片文件存储的位置)
        	alias html/hls/;
        	#响应头设置 禁止缓存 HLS 分片文件
        	add_header Cache-Control no-cache;
        }

使用ffmpeg,将摄像头rtsp转为rtmp并推送到nginx

如果你使用的是海康威视得摄像头构成一般为rtsp://摄像头用户名:密码@摄像头IP:摄像头端口/Streaming/Channels/摄像头标识

bash 复制代码
ffmpeg -rtsp_transport tcp -i  rtsp://摄像头IP:摄像头端口/Streaming/Channels/1  -c copy -f flv rtmp://nginx所在服务器IP:刚才配置RTMP模块监听端口/rtmp模块中application后面跟着的路径/自定义流的名称

VLC播放验证

VLC->媒体->打开媒体串流

播放地址如下:

http://nginx服务器IP:配置代理的端口(server中定义的)/location定义的代理地址/ffmpeg中自定义的流的名称.m3u8

相关推荐
Object~19 小时前
2.变量声明
开发语言·前端·javascript
IT_陈寒19 小时前
Vite 3实战:我用这5个优化技巧让HMR构建速度提升了40%
前端·人工智能·后端
阿干tkl19 小时前
Linux Web终端连接
linux·运维·前端
大爱编程♡19 小时前
JAVAEE-前端三剑客
java·前端·java-ee
下雨打伞干嘛19 小时前
前端学习官网文档
前端·学习
维李设论19 小时前
从2025看2026前端发展趋势
前端·架构·aigc·ai编程·大前端·趋势·前端工程师
释怀不想释怀19 小时前
vue前端crud(页面布局,新增,vue中反向代理)
前端·javascript·vue.js
jianghusanren319 小时前
【无标题】
ffmpeg
键盘飞行员19 小时前
Vue3 + Vite + MapboxGL 实战:集成 SuperMap iServer 加载 CGCS2000 地图服务与自定义标记
前端
麦麦大数据19 小时前
F068 vue+flask 非遗文化遗产图谱可视化系统
前端·vue.js·flask·知识图谱·文化遗产·非遗文化