使用ffmpeg+node-media-server实现从rtsp服务器拉流再推送至rtmp服务器,实现http+flv进行web播放

最近由于项目的需要,需要从海康的摄像头中读取视频流然后在web页面上展示。

由于海康摄像头使用了rtsp协议提供视频拉流服务,而web页面目前使用的插件不支持直接播放rtsp协议的视频流;因此考虑使用ffmpeg从rtsp中拉流,再推流至rtmp服务器,由于现在使用的测试环境是一台window的服务器,一般的rtmp服务器支持最多的是linux版本;这个rtmp服务器window版本的选择又转了一大圈;

首先想到的是使用srs的window版本,但发现在ffmpeg推流时,从srs中读取流时,过了1分钟左右,播放的流就中断了,再也读取不到流了,也没有明显的错误日志;

然后想到了nginx的rtmp模块和flv模块,但这个nginx配置rtmp模块+flv模块在window上,有点麻烦;只好继续找有没有更合适的服务器框架;

无意间,查到了node-media-server服务器也可以提供支持rtmp+http+flv的服务,安装后推流拉流,发现在window上还非常稳定;最后就选型了node-media-server。

下面把整体的ffmpeg推流,node-media-server配置,web播放视频流记录如下:

一、配置node-media-server支持rtmp服务器
1.使用npm安装node-media-server模块

在powershell中执行npm install node-media-server来安装node-media-server模块;

2.编写rtmp-server.js调用node-media-server提供rtmp和http+flv服务

完成node-media-server的安装后,编写rtmp-server.js调用node-media-server提供rtmp和http+flv服务,rtmp-server.js内容如下:

const NodeMediaServer= require('node-media-server');

const config = {

rtmp: {

port: 1935,

chunk_size: 60000,

gop_cache: true,

ping: 60,

ping_timeout: 30

},

//端口是登录nms服务器后台查看界面

http: {

port: 8099,

allow_origin: '*',

}

};

var nms = new NodeMediaServer(config)

nms.run();

3.启动运行rtmp-server.js,开始rtmp服务

在powershell中执行: node rtmp-server.js,开启服务;这时rrtmp的服务端口为1935,http服务的端口为8099;

可以通过http://127.0.0.1:8099/admin查看node-media-server的服务是否正常、查看对应的视频流列表。

二、使用ffmpeg从rtsp中拉流+推流至rtmp服务器(node-media-server)

ffmpeg -i "rtsp服务器url地址" -vcodec h264 -acodec aac -f flv rtmp://127.0.0.1:1935/live/livestream

三、web页面中播放视频流

在html中的video标签中配置src为http://127.0.0.1:8099/live/livestream.flv进行视频播放;

相关推荐
CHS_Lab2 小时前
“非标”MP4文件的恢复方法
ffmpeg·数据恢复·视频恢复·mp4恢复
一点晖光2 小时前
ffmpeg视频分辨率转换
ffmpeg·音视频
数据库生产实战3 小时前
Oracle的DBMS_SPACE.SPACE_USAGE和dba_segments计算的对象块数为什么不一样?表空间异常暴增的秘密可能就在这里!
oracle·ffmpeg·dba
hjjdebug14 小时前
ffmpeg -map 是什么意思?
ffmpeg·map
黑客思维者1 天前
Python自动化截图/录屏3大方案(PIL/mss/ffmpeg)深度拆解
python·ffmpeg·自动化·录屏
一点晖光1 天前
ffmpeg处理视频命令整理
ffmpeg·音视频
Everbrilliant891 天前
FFmpeg解码视频数据OpenGL Texture播放
ffmpeg·音视频·音视频解码·ffmpeg解码·opengl播放视频·ffmpeg解码gl播放·opengl render
花启莫你是不是傻1 天前
鸿蒙下FFmpeg编译流程梳理
华为·ffmpeg·harmonyos
千里马-horse2 天前
FFmpeg 工具文档
ffmpeg
一点晖光2 天前
ffmpeg合成的视频在ios浏览器不能播放的问题
ffmpeg·音视频