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

相关推荐
前端开发爱好者4 分钟前
“最新国产代码大杀器”——MiniMax-M2!
前端·javascript
小马哥编程31 分钟前
【软考架构】案例分析-web应用设计:SSH 和 SSM(Spring + Spring MVC + MyBatis ) 之间的区别,以及使用场景
前端·架构·ssh
用户1031133116636 分钟前
Vuex学习记录
前端
前端开发爱好者38 分钟前
Electron 淘汰!新的跨端框架来了!性能飙升!
前端·javascript
狮子座的男孩43 分钟前
js基础:08、构造函数(共享方法)、原型(prototype)、原型对象、(修改原型)toString方法、垃圾回收
前端·javascript·经验分享·prototype·垃圾回收·构造函数·原型对象
前端开发爱好者1 小时前
Vue 团队成员又搞了个 "新玩具"!
前端·javascript·vue.js
用户0136087566881 小时前
前端实现文件上传功能
前端
咖啡の猫2 小时前
Vue-github 用户搜索案例
前端·vue.js·github
yong99902 小时前
响应式布局新利器:CSS Grid 的 grid-template-areas 实战
前端·css
咖啡の猫2 小时前
Vue过度与动画
前端·javascript·vue.js