学会这个!!!你也可以搞定自己的流媒体服务器

1,870 阅读6分钟

1 使用场景

  • 接入支持国标(GB28181) 的摄像头推流到自己的管理平台
  • 对部分不支持前端播放的流,如RTSP 进行转流播放

2 文档 - 仓库

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\resourcesstatic即打包后文件夹

3.3 redis mysql准备

注意 mysql的数据库 名字为 wvp2

执行 数据库 目录下的最新sql文件即可

3.4 编译wvp-pro代码

此处有一个说明,截至文章发布时,编译时是不能选择环境的

因此部署时需要同时把 application.yml 文件 和 jar 包 一并上传

  • 正常的执行打包流程
  • application.ymlapplication-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的管理界面会出现已经上线的设备

如无法上线 请重新配置设备 image.png

此时通道点开即可看到播放界面

image.png

如果无法播放 请配置

image.png

5.3 拉流转流

此功能是 zlm的功能 和wvp-pro无关

浏览器访问地址

http://{zlm ip}:{docker 80端口对应的映射}/webassist/?secret={docker中复制的值}

完整的播放地址 http://192.169.120.132:8081/webassist/?secret=jaLkl0ut1i8VKKz8GyihHcJu7xLXWJ5d

拉流转流

image.png

播放流规则

参考文档


恭喜你到此处 你的流媒体平台已经搭建成功了