已经完成了ZMLMediaKit的部署,服务器已经可以实现推拉流等操作了。
接下来就是部署一套国标平台,完成设备国标注册功能,同时使用ZMLMediaKit完成视频推拉流操作。wvp就是这样一个平台。
开箱即用的28181协议视频平台
WEB VIDEO PLATFORM是一个基于GB28181-2016标准实现的开箱即用的网络视频平台,负责实现核心信令与设备管理后台部分,支持NAT穿透,支持海康、大华、宇视等品牌的IPC、NVR接入。支持国标级联,支持将不带国标功能的摄像机/直播流/直播推流转发到其他国标平台。
流媒体服务基于@夏楚 ZLMediaKit https://github.com/ZLMediaKit/ZLMediaKit
播放器使用@dexter jessibuca GitHub - langhuihui/jessibuca: Jessibuca是一款开源的纯H5直播流播放器
前端页面基于@Kyle MediaServerUI MediaServerUI: 基于ZLMediaKit主线的管理WEB网站 进行修改.
官方部署说明:WVP-PRO文档
这边同样做下记录
1 服务介绍
服务 | 作用 | 是否必须 |
---|---|---|
WVP-PRO | 实现国标28181的信令以及视频平台相关的功能 | 是 |
ZLMediaKit | 为WVP-PRO提供国标28181的媒体部分的实现,以及各种视频流格式的分发支持 | 是 |
wvp-pro-assist | wvp的辅助录像程序,也可单独跟zlm一起使用,提供录像控制,录像合并下载接口 | 否(不安装只是影响云端录像功能和国标录像下载) |
2 安装依赖
依赖 | 版本 | 用途 | 开发环境需要 | 生产环境需要 |
---|---|---|---|---|
jdk | >=1.8 | 运行与编译java代码 | 是 | 是 |
maven | >=3.3 | 管理java代码依赖 | 否 | 否 |
git | 下载/更新/提交代码 | 否 | 否 | |
nodejs | 编译于运行前端文件 | 否 | 否 | |
npm | 管理前端文件依赖 | 否 | 否 |
如果你是一个新手,建议你使用linux或者macOS平台。windows不推荐。
ubuntu环境,以ubuntu 18为例:
apt-get install -y openjdk-11-jre git maven nodejs npm复制错误已复制复制错误已复制
centos环境,以centos 8为例:
yum install -y java-1.8.0-openjdk.x86_64 git maven nodejs npm复制错误已复制复制错误已复制
window环境,以windows10为例:
这里不细说了,百度或者谷歌一搜一大把,基本都是下一步下一步,然后配置环境变量。复制错误已复制复制错误已复制
3 安装mysql以及redis
这里依然是参考网上教程,自行安装吧。
4 编译ZLMediaKit
参考ZLMediaKitWIKI,截取一下关键步骤:
# 国内用户推荐从同步镜像网站gitee下载 git clone --depth 1 https://gitee.com/xia-chu/ZLMediaKit cd ZLMediaKit # 千万不要忘记执行这句命令 git submodule update --init复制错误已复制复制错误已复制
5 编译WVP-PRO
5.1 可以通过git克隆,也可以在项目下载点击下载
从gitee克隆
git clone https://gitee.com/pan648540858/wvp-GB28181-pro.git复制错误已复制复制错误已复制
从github克隆
git clone https://github.com/648540858/wvp-GB28181-pro.git复制错误已复制复制错误已复制
5.2 编译前端页面
cd wvp-GB28181-pro/web_src/ npm --registry=https://registry.npm.taobao.org install npm run build复制错误已复制复制错误已复制
编译如果报错, 一般都是网络问题, 导致的依赖包下载失败
编译完成后在src/main/resources下出现static目录 编译完成一般是这个样子,中间没有报红的错误信息
PS:如果编译前端代码出现pyg错误,首先查看nodejs版本,请切换到nodejs-v12或v14版本进行尝试。
5.3 打包项目, 生成可执行jar
cd wvp-GB28181-pro mvn package复制错误已复制复制错误已复制
编译如果报错, 一般都是网络问题, 导致的依赖包下载失败
编译完成后在target目录下出现wvp-pro-***.jar。
截止到这里,就已经完成了wvp最新版本的编译工作。接下来我们需要配置程序启动参数。
配置
对于首次测试或者新手同学,我建议在局域网测试,并且关闭服务器与客户机的防火墙测试。建议部署在linux进行测试。
WVP-PRO通过调用ZLMediaKit的RESTful接口实现对ZLMediaKit行为的控制; ZLMediaKit通过Web Hook 接口把消息通知WVP-PRO。通过这种方式,实现了两者的互通。 对于最简单的配置,你不需要修改ZLMediaKit的任何默认配置。你只需要在WVP-PRO中配置的ZLMediaKit信息即可
1 WVP配置文件位置
基于spring boot的开发方式,配置文件的加载是很灵活的。默认在src/main/resources/application.yml,部分配置项是可选,你不需要全部配置在配置文件中, 完全的配置说明可以参看all-application.yml。
1.1 默认加载配置文件方式
使用maven打包后的jar包里,已经存在了配置文件,但是每次打开jar包修改配置文件或者修改后再打包都是比较麻烦的,所以大家可通过指定配置文件路径来加载指定位置的配置文件。
cd wvp-GB28181-pro/target java -jar wvp-pro-*.jar --spring.config.location=../src/main/resources/application.yml复制错误已复制
1.2 迁移配置文件以方便启动
由于配置文件的命令比较长,所以为了启动方便通常我会把配置文件放到jar包的同级目录,类似这样, 移除jar包内/BOOT-INF/classes/下所有以application开头的文件,使用解压缩工具打开jar即可,不需要解压出来。
cd wvp-GB28181-pro/target mv ../src/main/resources/application-dev.yml application.yml java -jar wvp-pro-*.jar 复制错误已复制
这也是我自己最常用的方式。
2 配置WVP-PRO
2.1 Mysql数据库配置
首先你需要创建一个名为wvp(也可使用其他名字)的数据库,并使用sql/mysql.sql导入数据库,初始化数据库结构。 在application-dev.yml中配置(使用1.2方式的是在jar包的同级目录的application.yml)配置数据库连接,包括数据库连接信息,密码。
2.2 Redis数据库配置
配置wvp中的redis连接信息,建议wvp自己单独使用一个db。
2.3 配置服务启动端口(可直接使用默认配置)
# [可选] WVP监听的HTTP端口, 网页和接口调用都是这个端口 server: port: 18080复制错误已复制
2.4 配置28181相关信息(可直接使用默认配置)
# 作为28181服务器的配置 sip: # [必须修改] 本机的IP ip: 192.168.1.3 # [可选] 28181服务监听的端口 port: 5060 # 根据国标6.1.2中规定,domain宜采用ID统一编码的前十位编码。国标附录D中定义前8位为中心编码(由省级、市级、区级、基层编号组成,参照GB/T 2260-2007) # 后两位为行业编码,定义参照附录D.3 # 3701020049标识山东济南历下区 信息行业接入 # [可选] domain: 3402000000 # [可选] id: 34020000002000000001 # [可选] 默认设备认证密码,后续扩展使用设备单独密码, 移除密码将不进行校验 password: 12345678复制错误已复制
2.5 配置ZLMediaKit连接信息
#zlm 默认服务器配置 media: # ZLMediaKit的服务ID,必须配置 id: FQ3TF8yT83wh5Wvz # [必须修改] zlm服务器的内网IP,sdp-ip与stream-ip使用默认值的情况下,这里不要使用127.0.0.1/0.0.0.0 ip: 192.168.1.3 # [必须修改] zlm服务器的http.port http-port: 6080 # [可选] zlm服务器的hook.admin_params=secret secret: 035c73f7-bb6b-4889-a715-d9eb2d1925cc # 启用多端口模式, 多端口模式使用端口区分每路流,兼容性更好。 单端口使用流的ssrc区分, 点播超时建议使用多端口测试 rtp: # [可选] 是否启用多端口模式, 开启后会在portRange范围内选择端口用于媒体流传输 enable: true # [可选] 在此范围内选择端口用于媒体流传输, port-range: 30000,30500 # 端口范围 # [可选] 国标级联在此范围内选择端口发送媒体流, send-port-range: 30000,30500 # 端口范围 # 录像辅助服务, 部署此服务可以实现zlm录像的管理与下载, 0 表示不使用 record-assist-port: 18081复制错误已复制
2.4 个性化定制信息配置
# [根据业务需求配置] user-settings: # [可选] 服务ID,不写则为000000 server-id: # [可选] 自动点播, 使用固定流地址进行播放时,如果未点播则自动进行点播, 需要rtp.enable=true auto-apply-play: false # [可选] 部分设备需要扩展SDP,需要打开此设置 senior-sdp: false # 保存移动位置历史轨迹:true:保留历史数据,false:仅保留最后的位置(默认) save-position-history: false # 点播等待超时时间,单位:毫秒 play-timeout: 3000 # 等待音视频编码信息再返回, true: 可以根据编码选择合适的播放器,false: 可以更快点播 wait-track: false # 是否开启接口鉴权 interface-authentication: true # 自动配置redis 可以过期事件 redis-config: true # 接口鉴权例外的接口, 即不进行接口鉴权的接口,尽量详细书写,尽量不用/**,至少两级目录 interface-authentication-excludes: - /api/v1/** # 推流直播是否录制 record-push-live: true # 国标是否录制 record-sip: true # 是否将日志存储进数据库 logInDatebase: true # 第三方匹配,用于从stream钟获取有效信息 thirdPartyGBIdReg: [\s\S]*复制错误已复制
如果配置信息无误,你可以启动zlm,再启动wvp来测试了,启动成功的话,你可以在wvp的日志下看到zlm已连接的提示。
本文链接:https://hqyman.cn/post/8228.html 非本站原创文章欢迎转载,原创文章需保留本站地址!