流媒体拉流服务器,支持媒体格式化.用于上传
原名:流媒体拉流服务器(TXPPullServer),随着各位支持的深入,增加了很多功能。现在已经不单单是推流服务器了,同时兼备了推拉流的业务
主要功能
直播推拉流 推拉流服务 加密推流 视频录制功能 为媒体文件转码成M3U8格式文件实现拉流服务,通过以下三种生成方式生成M3U8文件: 服务器本地路径转码 URL下载转码 multipart/form-data方式上传转码系统服务依赖 ffmpeg 安装系统只支持转成m3u8格式,m3u8格式适合android和ios播放,rmtp部分手机机型播放有限制
npm install //配置 config.js node test.js //检查配置 测试
启动npm run test
设置 ./config.js 全局配置 ./apiServer/fillterRouter 配置不需要token验证的过滤路由地址(如不修改接口无需改变) API列表npm start //运行api服务 npm run live //运行推拉流服务器,如不需要推拉流服务可不运行
请求./流媒体拉流服务器POSTMAN测试(可导入)是一个postman文件,可导入,内部有所有接口测试数据
POST请求,为JSON体
返回{ "code": "200", "data": {}, //返回值 "msg": "code == 200 ? null : 错误提示" } 错误code码
错误码 | 意义 |
---|---|
200 | 正确 |
444 | 密钥错误,配置 ./config apiServer.publicKey 注意!! 是数组 |
500 | 程序错误 |
40500 | 程序错误 |
40501 | 系统仅支持MP4格式 |
40502 | 回调地址必须为URL |
40503 | 硬盘文件不存在 |
40504 | 下载错误或文件不存在,无法创建任务 |
40505 | 系统仅支持m3u8格式 |
40506 | 房间名称必须存在 |
40507 | 必须规定直播结束时间 |
GET /version 获取服务器版本号
GET /hls
@way disk=硬盘转存 | url 网络地址转存 @uri 资源位置,对应@way的方式 @cover 数组,截取封面 @callback 格式化m3u8任务完成后,回调地址,例如:http://localhost/version?id=12POST /update multipart/form-data方式上传
@file 资源位置 @cover 数组,截取封面 @callback 格式化m3u8任务完成后,回调地址,例如:http://localhost/version?id=12{ "code": "200", "data": { "liveAddress": "http://127.0.0.1:8080/2021/06/23/16244291330001079509548/162442913300010795095480.m3u8", "hdAddress": "http://127.0.0.1:8080/2021/06/23/16244291330001079509548/162442913300010795095481.m3u8", "cover": [ "http://127.0.0.1:8080/2021/06/23/16244291330001079509548/881045828.jpg", "http://127.0.0.1:8080/2021/06/23/16244291330001079509548/262820368.jpg" ] }, "msg": null } 2.0版本集成了推拉流服务器
启动方式:
npm run live
相关配置
//推流服务器相关配置 live:{ //拉流服务端口地址 推流上来后,通过这个接口拉流 例如 http://192.168.1.179:8000/live/自己定义的密钥 可获取到直播流 m3u8地址 port:8000, //直播缓存地址 mediaroot:path.resolve(__dirname,'./live/media/'), //推流服务器配置 rtmp:{ port: 1935, //推流推这个端口!! rtmp://192.168.1.179:1935/live/自己定义的密钥 chunk_size: 60000, gop_cache: true, ping: 60, ping_timeout: 30 } }
通过API进行推流录制
GET /recording @m3u8 录制的地址 @callback 录制完成后的回调地址录制完成后,会像回调地址GET发送相关录制的文件URI位置
{ //回调中你自定义的所有数据 id: '1', //服务器硬盘地址 diskuri: '/Users/wos/Desktop/live-server/mediaDisk/2021/06/26/162467712400085134759/162467712400085134759.mp4', //网络MP4地址 neturi: 'http://127.0.0.1:8080/2021/06/26/162467712400085134759/162467712400085134759.mp4', //时间戳 t: '1624677138000' }
推流加密录制并不生成M3U8文件,用户可根据回调自行判断是否生成m3u8文件或封面
2.0版本推拉流地址是公开的,其他用户可以通过拉流地址计算推流地址,在2.1版本中加入推拉流鉴权的功能
如需开启推流加密,配置config.js中 live.secret = true
GET /liveSign @endTimestamp 结束直播的时间戳,注意不是毫秒级时间戳!!! @roomName 房间名称入参:
http://localhost:8080/liveSign?endTimestamp=1624701820&roomName=wos
出参
{ "code": "200", "data": { "sign": "1624701820-81be5df8e39a40a0602490e74cb3d517" }, "msg": null }
推流地址就是
rtmp://ip:1935/live/wos?sign=1624701820-81be5df8e39a40a0602490e74cb3d517 推拉流服务器相关的API 获取服务器资源 http://localhost:8000/api/server 推流状况 http://localhost:8000/api/streams 大屏数据展示 http://localhost:8000/admin/
如需关闭大屏数据展示接口,请使用nginx反向代理8000后,自定义过滤
location ~ / { if ( $query_string ~* ^(.*)?s=/admin ){ return 555; } } ...
版权声明:
1、该文章(资料)来源于互联网公开信息,我方只是对该内容做点评,所分享的下载地址为原作者公开地址。2、网站不提供资料下载,如需下载请到原作者页面进行下载。