1 使用场景
- 接入支持国标(GB28181) 的摄像头推流到自己的管理平台
- 对部分不支持前端播放的流,如RTSP 进行转流播放
2 文档 - 仓库
- WVP-PRO
- ZLMediaKit
3 搭建流媒体平台
3.1 准备工作
- 克隆
wvp-pro的代码到本地 - 在服务器使用docker 拉取镜像
docker run -id -p 1935:1935/tcp -p 1935:1935/udp -p 8081:80 -p 8443:443/tcp -p 8443:443/udp -p 8554:554/tcp -p 8554:554/udp -p 10000:10000/tcp -p 10000:10000/udp -p 8000:8000/tcp -p 8000:8000/udp -p 9000:9000/udp -p 50001-50037:50001-50037/udp -p 50001-50037:50001-50037/tcp zlmediakit/zlmediakit:master
此处需要注意几个点
-p 8081: 80此处的8081 需要对用后续配置中的wvp-pro配置-p 50001-50037:50001-50037此处的端口范围可以自定义但是至少需要36个- 尽量把tcp-udp 端口都放开
3.2 编译前端代码
- 克隆 wvp-GB28181-pro 到本地
web_src目录下 进行build打包- 打包不成功记得切换
node版本 我用的12.22.12 - 打包之后的文件在
src\main\resources下static即打包后文件夹
3.3 redis mysql准备
注意 mysql的数据库 名字为 wvp2
执行 数据库 目录下的最新sql文件即可
3.4 编译wvp-pro代码
此处有一个说明,截至文章发布时,编译时是不能选择环境的
因此部署时需要同时把
application.yml文件 和 jar 包 一并上传
- 正常的执行打包流程
application.yml和application-dev.yml一并上传部署
3.5 部署ZLMediaKit
- 执行上边的
docker代码后 - 进入容器
/opt/media/conf目录下 - 打开 conf.ini 文件 粘贴出来两个值
secret=jaLkl0ut1i8VKKz8GyihHcJu7xLXWJ5d
mediaServerId=your_server_id
此时 我们的环境已经搭建完毕
4 修改相关配置并启动流媒体平台
4.1 application-dev.yml 文件配置说明
#[可选] WVP监听的HTTP端口, 网页和接口调用都是这个端口
server:
port: 18082
# [可选] HTTPS配置, 默认不开启
ssl:
# [可选] 是否开启HTTPS访问
enabled: false
# [可选] 证书文件路径,放置在resource/目录下即可,修改xxx为文件名
key-store: classpath:test.monitor.89iot.cn.jks
# [可选] 证书密码
key-store-password: gpf64qmw
# [可选] 证书类型, 默认为jks,根据实际修改
key-store-type: JKS
# 作为28181服务器的配置
sip:
# [必须修改] 本机的IP,对应你的网卡,监听什么ip就是使用什么网卡,
# 如果要监听多张网卡,可以使用逗号分隔多个IP, 例如: 192.168.1.4,10.0.0.4
# 如果不明白,就使用0.0.0.0,大部分情况都是可以的
# 请不要使用127.0.0.1,任何包括localhost在内的域名都是不可以的。
# 建议直接使用网卡ip
ip: 192.168.125.248
# [可选] 28181服务监听的端口
port: 28181
# 根据国标6.1.2中规定,domain宜采用ID统一编码的前十位编码。国标附录D中定义前8位为中心编码(由省级、市级、区级、基层编号组成,参照GB/T 2260-2007)
# [可选]
domain: 4101050000
# [可选]
id: 41010500002000000001
# [可选] 默认设备认证密码,后续扩展使用设备单独密码, 移除密码将不进行校验
password: 123456
# 是否存储alarm信息
alarm: true
#zlm 默认服务器配置
media:
id: your_server_id
# [必须修改] zlm服务器的内网IP
ip: 192.168.125.248
# [必须修改] zlm服务器的http.port
http-port: 8081
# [可选] 返回流地址时的ip,置空使用 media.ip
stream-ip: 192.168.125.248
# [可选] wvp在国标信令中使用的ip,此ip为摄像机可以访问到的ip, 置空使用 media.ip
sdp-ip: 221.6.37.166
# [可选] zlm服务器的hook所使用的IP, 默认使用sip.ip
hook-ip: 192.168.125.248
# [可选] zlm服务器的http.sslport, 置空使用zlm配置文件配置
http-ssl-port: 1443
# [可选] zlm服务器的hook.admin_params=secret
secret: avRBjssWoESJIIpZw7e83N7BohrtpUCA
# 启用多端口模式, 多端口模式使用端口区分每路流,兼容性更好。 单端口使用流的ssrc区分, 点播超时建议使用多端口测试
rtp:
# [可选] 是否启用多端口模式, 开启后会在portRange范围内选择端口用于媒体流传输
enable: true
# [可选] 在此范围内选择端口用于媒体流传输, 必须提前在zlm上配置该属性,不然自动配置此属性可能不成功
# 此处的prot范围 请和docker镜像的port范围保持一致
port-range: 50001,50037 # 端口范围
# [可选] 国标级联在此范围内选择端口发送媒体流,
send-port-range: 50001,50037 # 端口范围
# 录像辅助服务, 部署此服务可以实现zlm录像的管理与下载, 0 表示不使用
record-assist-port: 18081
# [根据业务需求配置]
user-settings:
# 点播/录像回放 等待超时时间,单位:毫秒
play-timeout: 120000
# [可选] 自动点播, 使用固定流地址进行播放时,如果未点播则自动进行点播, 需要rtp.enable=true
auto-apply-play: true
# 设备/通道状态变化时发送消息
device-status-notify: true
配置参数的额外说明
- sip 参数
- IP 建议直接使用网卡ip
- media参数
- id 与docker镜像中的值保持一致
- ip
- 如果zlm和wvpro都在内网部署 请使用 zlm 服务所在的内网ip
- 如果公网网部署 请使用zlm所在的公网ip 记得端口开放
- http-port 此处请与 -p 8081: 80 的端口对应
- stream-ip zlm 内网ip
- sdp-ip 一定是设备可以访问的公网ip
- secret 与docker镜像中的值保持一致
4.2 nginx代理wvp-pro的管理页面
使用nginx代理前端打包后的代码
登录 admin admin
5 如何使用
5.1 设备配置与接入
参考 如何接入设备
5.2 wvp-pro 拉取国标设备
配置完成后,wvp-pro的管理界面会出现已经上线的设备
如无法上线 请重新配置设备
此时通道点开即可看到播放界面
如果无法播放 请配置
5.3 拉流转流
此功能是 zlm的功能 和wvp-pro无关
浏览器访问地址
http://{zlm ip}:{docker 80端口对应的映射}/webassist/?secret={docker中复制的值}
完整的播放地址 http://192.169.120.132:8081/webassist/?secret=jaLkl0ut1i8VKKz8GyihHcJu7xLXWJ5d
拉流转流
播放流规则
恭喜你到此处 你的流媒体平台已经搭建成功了