Ubuntu搭建国标平台wvp-GB28181-pro

news2025/1/11 7:47:39

目录

  • 简介
  • 安装和编译
    • 1.查看操作系统信息
    • 2.安装最新版的nodejs
    • 3.安装java环境
    • 4.安装mysql
    • 5.安装redis
    • 6.安装编译器
    • 7.安装cmake
    • 8.安装依赖库
    • 9.编译ZLMediaKit
      • 9.1.编译结果说明
    • 10.编译wvp-GB28181-pro
      • 10.1.编译结果说明
  • 配置
    • 1.WVP-PRO配置文件
      • 1.1.Mysql数据库配置
      • 1.2.REDIS数据库配置
      • 1.3.配置服务启动端口
      • 1.4.配置28181相关信息
      • 1.5.配置ZLMediaKit连接信息
      • 1.6.个性化定制信息配置
    • 2.ZLMediaKit配置文件
      • 2.1.文件使用
      • 2.1.配置
  • 运行测试
    • 1.运行ZLMediaKit
      • 1.1.ZLMediaKit测试命令
    • 2.运行wvp-GB28181-pro
      • 2.1.测试命令
    • 3.添加GB28181设备模拟器
  • 参考资料

简介

官网wvp-GB28181-pro: https://doc.wvp-pro.cn/#/

流媒体服务器: https://github.com/ZLMediaKit/ZLMediaKit

WVP-PRO使用Spring boot开发,maven管理依赖。

参考官网既可安装部署.

为了方便搭建,开源软件以后修改可能导致配置失败,把ZLMediaKit和wvp-GB28181-pro配置文件和项目commit ID记录到仓库中.

https://gitee.com/fedorayang/wvp-gb28181-pro_-zlmedia-kit_config.git

安装和编译

Ubuntu 22.04.3 LTS为例

1.查看操作系统信息

lsb_release -a
#输出一下信息
LSB Version:    core-11.1.0ubuntu4-noarch:security-11.1.0ubuntu4-noarch
Distributor ID: Ubuntu
Description:    Ubuntu 22.04.3 LTS
Release:        22.04
Codename:       jammy

2.安装最新版的nodejs

参考 ubuntu安装nodejs环境: https://blog.csdn.net/fedorayang/article/details/135837204

3.安装java环境

sudo apt install -y openjdk-11-jre maven

#确认java安装成功
java --version
#输出版本信息
openjdk 11.0.21 2023-10-17
OpenJDK Runtime Environment (build 11.0.21+9-post-Ubuntu-0ubuntu122.04)
OpenJDK 64-Bit Server VM (build 11.0.21+9-post-Ubuntu-0ubuntu122.04, mixed mode, sharing)

4.安装mysql

mysql如果以前安装过其他数据库可能存在冲突,需要完全卸载后安装,具体安装步骤参考 myql入门: https://blog.csdn.net/fedorayang/article/details/135847981

5.安装redis

sudo apt update
sudo apt install redis-server

#启动
redis-server

#查看Redis是否正常
systemctl status redis
redis-cli
#输入ping返回PONG表示正常

6.安装编译器

sudo apt install build-essential

7.安装cmake

参考文章 cmake入门: https://blog.csdn.net/fedorayang/article/details/134513536

8.安装依赖库

#除了openssl,其他其实都可以不安装
sudo apt install -y libssl-dev
sudo apt install -y libsdl1.2-dev
sudo apt install -y libavcodec-dev
sudo apt install -y libavutil-dev
sudo apt install -y ffmpeg

9.编译ZLMediaKit

git clone --depth 1 https://gitee.com/xia-chu/ZLMediaKit
cd ZLMediaKit
git submodule update --init
#编译
mkdir build
cd build
cmake ..
make -j4

9.1.编译结果说明

编译结果在release目录下,主要有三部分组成:

  • MediaServer 进程

    cd ZLMediaKit/release/linux/Debug
    #通过-h可以了解启动参数
    ./MediaServer -h
    
  • c api 的 SDK

头文件在ZLMediaKit/api/include
库文件为:ZLMediaKit/release/linux/Debug/libmk_api.so
  • test_开头的测试程序

相关代码在ZLMediaKit/tests目录下,你可以对照代码启动测试进程。

10.编译wvp-GB28181-pro

git clone https://gitee.com/pan648540858/wvp-GB28181-pro.git

#1.编译前端页面
cd wvp-GB28181-pro/web_src/
npm --registry=https://registry.npmmirror.com install
npm run build
#编译完成后会生成目录: wvp-GB28181-pro/src/main/resources/static

#2.生成可执行jar
cd wvp-GB28181-pro
mvn package
#编译后生成文件: wvp-GB28181-pro/target/wvp-pro-2.7.0-01260305.jar

#3.生成war
cd wvp-GB28181-pro
mvn package -P war
#编译后生成文件: wvp-GB28181-pro/target/wvp-pro-2.7.0-01260312.war

10.1.编译结果说明

最终编译生成的结果在wvp-GB28181-pro/target目录,内容如下:
在这里插入图片描述

配置

有两个配置文件:1.WVP-PRO配置文件;2.ZLMediaKit配置文件.

1.WVP-PRO配置文件

./src/main/resources/application.yml
./target/classes/application.yml
./target/wvp-pro-2.7.0-01260312/WEB-INF/classes/application.yml

./src/main/resources/all-application.yml
./target/classes/all-application.yml
./target/wvp-pro-2.7.0-01260312/WEB-INF/classes/all-application.yml

如上all-application.yml,application.yml使用哪一组都可以,这里使用all-application.yml进行修改.

1.1.Mysql数据库配置

这里有两点注意:

  • share数据库删除
  • master数据库wvp2需要修改为wvp,必须要和建立的数据库名称对应
# [必选] jdbc数据库配置
datasource:
	# mysql配置
	dynamic:
		primary: master
		datasource:
			master:
				type: com.zaxxer.hikari.HikariDataSource
				driver-class-name: com.mysql.cj.jdbc.Driver
				url: jdbc:mysql://127.0.0.1:3306/wvp?useUnicode=true&characterEncoding=UTF8&rewriteBatchedStatements=true&serverTimezone=PRC&useSSL=false&allowMultiQueries=true
				username: root
				password: root123
				hikari:
					connection-timeout: 20000             # 是客户端等待连接池连接的最大毫秒数
					initialSize: 50                       # 连接池初始化连接数
					maximum-pool-size: 200                # 连接池最大连接数
					minimum-idle: 10                       # 连接池最小空闲连接数
					idle-timeout: 300000                  # 允许连接在连接池中空闲的最长时间(以毫秒为单位)
					max-lifetime: 1200000                 # 是池中连接关闭后的最长生命周期(以毫秒为单位)

MySQL设置

#查看数据库状态
systemctl status mysql
#进入mysql
mysql -u root -p

#mysql更改
use mysql;
update user set host='%' where user= 'root';
flush privileges;
select host,user,plugin from user where user='root';
#更改root用户密码为root123,参考上面的配置
alter user 'root'@'%' identified with mysql_native_password by 'root123';
flush privileges;
grant all on *.* to 'root'@'%';
flush privileges;


#wvp数据库修改,需要和url: jdbc:mysql://127.0.0.1:3306/wvp?对应
create DATABASE wvp;
use wvp;
source /home/multimedia/gb28181/wvp-GB28181-pro/数据库/初始化-mysql.sql
flush privileges;
exit

1.2.REDIS数据库配置

1.3.配置服务启动端口

# [可选] WVP监听的HTTP端口, 网页和接口调用都是这个端口
server:
    port: 18080

1.4.配置28181相关信息

sip:
	#SIP信令服务器IP地址
    ip: 0.0.0.0
    port: 5060
    domain: 4401020049
    id: 44010200492000000001
    password: admin123

1.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: 80       
    # [可选] 返回流地址时的ip,置空使用 media.ip
    #stream-ip:
    # [可选] wvp在国标信令中使用的ip,此ip为摄像机可以访问到的ip, 置空使用 media.ip
    #sdp-ip:
    # [可选] zlm服务器的hook所使用的IP, 默认使用sip.ip
    #hook-ip:  
    # [可选] zlm服务器的http.sslport, 置空使用zlm配置文件配置
    #http-ssl-port:
    # [可选] zlm服务器的rtmp.port, 置空使用zlm配置文件配置
    #rtmp-port:
    # [可选] zlm服务器的rtmp.sslport, 置空使用zlm配置文件配置
    #rtmp-ssl-port:
    # [可选] zlm服务器的 rtp_proxy.port, 置空使用zlm配置文件配置
    #rtp-proxy-port:
    # [可选] zlm服务器的 rtsp.port, 置空使用zlm配置文件配置
    #rtsp-port:
    # [可选] zlm服务器的 rtsp.sslport, 置空使用zlm配置文件配置
    #rtsp-ssl-port:    
    # [可选] zlm服务器的hook.admin_params=secret
    secret: BkPj2ca6QPpY5RccREJq4kAOu9ZEt70x
    # 启用多端口模式, 多端口模式使用端口区分每路流,兼容性更好。 单端口使用流的ssrc区分, 点播超时建议使用多端口测试
    rtp:
        # [可选] 是否启用多端口模式, 开启后会在portRange范围内选择端口用于媒体流传输
        enable: true
        # [可选] 在此范围内选择端口用于媒体流传输, 必须提前在zlm上配置该属性,不然自动配置此属性可能不成功
        port-range: 30000,35000 # 端口范围
        # [可选] 国标级联在此范围内选择端口发送媒体流,请不要与收流端口范围重合
        send-port-range: 35002,35006 # 端口范围    
  • id必须和2.1.配置中general.mediaServerId设置一致
  • ip必须正确设置
  • http-port和2.1.配置中http.port相同
  • secret和2.1.配置中api.secret相同
  • rtp和2.1.配置中rtp_proxy.rtp_proxy相同

1.6.个性化定制信息配置

# [根据业务需求配置]
user-settings:
    # [可选] 服务ID,不写则为000000
    #server-id:

2.ZLMediaKit配置文件

2.1.文件使用

./release/linux/Debug/config.ini
./conf/config.ini

#默认使用./release/linux/Debug/config.ini

#修改并保存配置文件后,运行如下命令就能使ZLMediaKit热加载配置文件,而不必先关闭服务然后再开启
killall -1 MediaServer`

2.1.配置

[api]
    #一些比较敏感的http api在访问时需要提供secret,否则无权限调用
    #如果是通过127.0.0.1访问,那么可以不提供secret
    secret=BkPj2ca6QPpY5RccREJq4kAOu9ZEt70x

[general]
    #服务器唯一id,用于触发hook时区别是哪台服务器
    mediaServerId=FQ3TF8yT83wh5Wvz

[http]
    #http服务器监听端口
    port=80

[rtp_proxy]
    #随机端口范围,最少确保36个端口
    #该范围同时限制rtsp服务器udp端口范围
    port_range=30000-35000	
  • mediaServerId需要和1.5.配置ZLMediaKit连接信息中的ID设置一致
  • secret需要和1.5.配置ZLMediaKit相同

运行测试

1.运行ZLMediaKit

cd ZLMediaKit/release/linux/Debug
sudo ./MediaServer -c /home/multimedia/gb28181/config/ZLMediaKitConfig.ini

1.1.ZLMediaKit测试命令

http://192.168.1.3/
http://192.168.1.3/webassist/?secret=BkPj2ca6QPpY5RccREJq4kAOu9ZEt70x
https://192.168.1.3/webrtc/

2.运行wvp-GB28181-pro

cd wvp-GB28181-pro/target
#测试命令
sudo java -jar wvp-pro-*.jar --spring.config.location=/home/multimedia/gb28181/config/wvp-GB28181-pro-config.yml

2.1.测试命令

curl localhost:18080

http://192.168.1.3:18080/#/login
#用户名: admin
#密码: admin

3.添加GB28181设备模拟器

国标gb28181模拟环境搭建: https://blog.csdn.net/fedorayang/article/details/135498173

1.4.配置28181相关信息

<?xml version="1.0" encoding="utf-8"?>
<config>
    <server_ip>192.168.1.3</server_ip>
    <server_port>5060</server_port>
    <server_id>44010200492000000001</server_id>
    <server_domain>4401020049</server_domain>
    <password>admin123</password>
    <protocol>udp</protocol>
</config>

其他配置项默认.

设备模拟器配置好后,启动wvp-GB28181-pro自动识别到设备.
在这里插入图片描述
流传输模式:UDP,TCP被动模式最常用.

参考资料

国标gb28181保姆级入门教程: https://blog.csdn.net/fedorayang/article/details/135499219

全网首发 开源28181 国产开源系统openeuler 编译ZLMediaKit wvp-GB28181-pro: https://www.bilibili.com/video/BV1hA4y1S7Gw?vd_source=a795ec50b290a151c69819df1d6cb37a

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1419853.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

封装通用mixins,在vue中实现a-table组件的可伸缩列(详细且使用便捷)

1、实现效果 2、使用场景 vue2 antd-vue 1.x版本由于antd-vue 1.x版本的组件库没有提供可伸缩列的功能&#xff0c;才需要我们手动开发在antd-vue 3.x版本以上的表格已经支持这个功能&#xff0c;不需要我们再去手动开发 3、话不多说&#xff0c;上代码 首先安装vue-dragga…

Android MediaCodec 简明教程(四):使用 MediaCodec 将视频解码到 Surface,并使用 SurfaceView 播放视频

系列文章目录 Android MediaCodec 简明教程&#xff08;一&#xff09;&#xff1a;使用 MediaCodecList 查询 Codec 信息&#xff0c;并创建 MediaCodec 编解码器Android MediaCodec 简明教程&#xff08;二&#xff09;&#xff1a;使用 MediaCodecInfo.CodecCapabilities 查…

白嫖!平替ChatGPT,高效阅读文档,支持pdf上传!

大家好&#xff0c;我是阿潘&#xff0c;现在技术更新的太快了&#xff0c;每天arxiv上面更新的论文太多了看不过来&#xff0c;同时还有一大堆公众号、知识星球、知乎等等&#xff0c;太多需要关注的信息了&#xff0c;力不从心啊。但是又怕漏掉一些有用的信息 因此今天跟大家…

FastBee开源物联网平台2.0开源版发布啦!!!

一、项目介绍 物美智能(wumei-smart)更名为蜂信物联(FastBee)。 FastBee开源物联网平台&#xff0c;简单易用&#xff0c;更适合中小企业和个人学习使用。适用于智能家居、智慧办公、智慧社区、农业监测、水利监测、工业控制等。 系统后端采用Spring boot&#xff1b;前端采用…

怎么把word文档转换成pdf?几种高效转换方法了解一下

怎么把word文档转换成pdf&#xff1f;在当今这个时代&#xff0c;PDF已经成为一种通用的文件格式&#xff0c;广泛应用于各种场景。将Word文档转换为PDF&#xff0c;可以确保文档的格式、字体、图片等元素在各种设备和软件上保持一致。那么&#xff0c;如何将Word文档转换为PDF…

Liunx基础-----------------------第十六章网站服务

一、概念 UI的转变&#xff1a;B/S框架 HYML&#xff1a;超文本标记语言 网页&#xff1a;使用HTML&#xff0c;PHP&#xff0c;JAVA语言格式书写的文件 主页&#xff1a;网页中呈现用户的第一个页面 网站&#xff1a;多个网页组合而成的一台网站服务器 URL&#xff1a;统…

vue3封装el-pagination分页组件

1、效果如图&#xff1a; 2、分页组件代码&#xff1a; <template><div class"paging"><el-config-provider :locale"zhCn"><el-paginationv-model:current-page"page.currentPage"v-model:page-size"page.pageSize…

【BUG】golang gorm导入数据库报错 “unexpected type clause.Expr“

帮同事排查一个gorm导入数据报错的问题 事发现场 ck sql CREATE TABLE ods_api.t_sms_jg_msg_callback_dis (app_key String DEFAULT COMMENT 应用标识,callback_type Int32 DEFAULT 0 COMMENT 0送达&#xff0c;1回执,channel Int32 DEFAULT 0 COMMENT uid下发的渠道,mode…

element ui组件 el-date-picker设置default-time的默认时间

default-time &#xff1a;选择日期后的默认时间值。 如未指定则默认时间值为 00:00:00 默认值修改 <el-form-item label"计划开始时间" style"width: 100%;" prop"planStartTime"><el-date-picker v-model"formData.planStart…

安装elasticsearch、kibana、IK分词器

1.部署单点es 1.1.创建网络 因为我们还需要部署kibana容器&#xff0c;因此需要让es和kibana容器互联。这里先创建一个网络&#xff1a; docker network create es-net 1.2.加载镜像 这里我们采用elasticsearch的7.12.1版本的镜像&#xff0c;这个镜像体积非常大&#xff0…

flutter module打包成framework引入原生工程

Flutter - 将 Flutter 集成到现有项目&#xff08;iOS - Framework篇&#xff09; 本篇文章大幅参考了 caijinglong 大佬的总结文章&#xff1a; 把flutter作为framework添加到已存在的iOS中[1] 用 Flutter 来开发&#xff0c;从来都不可能是新开的一个纯 Flutter 项目&#xf…

vite+vue3 使用svg icon(包括element-plus icon)

1、安装依赖 npm i element-plus/icons-vue -S npm i vite-plugin-svg-icons -D2、在vite.config.ts文件中 import path from path; import { createSvgIconsPlugin } from vite-plugin-svg-icons; // 版本不同引入方式不同 export default defineConfig({...plugins: [...cr…

文件夹隐藏了怎么找出来?如何取消文件夹隐藏属性

在我们的日常工作中&#xff0c;经常会遇到文件夹被隐藏的情况&#xff0c;这可能会让我们在寻找需要的文件时感到困惑。那么&#xff0c;如何找回这些隐藏的文件夹呢&#xff1f;本文将为你提供一些实用的方法&#xff0c;帮助你解决这个问题。 图片来源于网络&#xff0c;如有…

温酒读Qt:QObject中篇2 ——欲遮还羞的 QObjectPrivate

《妙法莲华经》曰&#xff1a;“佛道长远&#xff0c;久受勤苦&#xff0c;乃可得成。” 世事修炼&#xff0c;莫不如是&#xff0c;日拱一卒无有尽&#xff0c;功不唐捐终入海。 传送门: 《温酒读Qt&#xff1a;QObject 序篇》 《温酒读Qt&#xff1a;QObject中篇1—— Q_OBJ…

宝塔控制面板配置SSL证书实现网站HTTPS

宝塔安装SSL证书提前申请好SSL证书&#xff0c;如果还没有&#xff0c;先去Gworg里面申请&#xff0c;一般几分钟就可以下来&#xff0c;申请地址&#xff1a;首页-Gworg官方店-淘宝网 一、登录邮箱下载&#xff1a;Gworg证书文件目录 &#xff0c;都会有以下五个文件夹。宝塔…

红外热成像仪定制_热成像仪/红外夜视仪开发方案

红外热成像技术是一种利用红外热成像仪将物体发出的不可见红外辐射能量转换成可见的温度场图像的技术&#xff0c;通过不同颜色来表示不同温度。这项技术的应用领域非常广泛&#xff0c;从电路维修到暖通检测再到汽车故障排查等各个领域都有着重要的作用。 红外热成像仪的解决方…

数字人解决方案VividTalk——音频驱动单张照片实现人物头像说话的效果

前言 VividTalk是一项由南京大学、阿里巴巴、字节跳动和南开大学共同开发的创新项目。该项目通过结合单张人物静态照片和一段语音录音&#xff0c;能够制作出一个看起来仿佛实际说话的人物视频。项目的特点包括自然的面部表情和头部动作&#xff0c;口型能够同步&#xff0c;同…

搞明白手机卡的合约期和优惠期才能避免很多坑!

很多朋友注销流量卡时才发现自己的套餐有合约期无法注销&#xff0c;尤其是联通和移动&#xff0c;那么什么是合约期呢&#xff1f;合约期和优惠期又有什么不一样呢&#xff1f;下来答案来了。 其实&#xff0c;目前很多在网上办理的大流量卡都是有合约期的&#xff0c;尤其是移…

05. 交换机的基本配置

文章目录 一. 初识交换机1.1. 交换机的概述1.2. Ethernet_ll格式1.3. MAC分类1.4. 冲突域1.5. 广播域1.6. 交换机的原理1.7. 交换机的3种转发行为 二. 初识ARP2.1. ARP概述2.2. ARP报文格式2.3. ARP的分类2.4. 免费ARP的作用 三. 实验专题3.1. 实验1&#xff1a;交换机的基本原…

JSP仓储管理系统myeclipse定制开发SQLServer数据库网页模式java编程jdbc

一、源码特点 JSP仓储管理系统系统是一套完善的web设计系统&#xff0c;对理解JSP java编程开发语言有帮助&#xff0c;系统具有完整的源代码和数据库 &#xff0c;系统主要采用B/S模式开发。开发环境为 TOMCAT7.0,Myeclipse8.5开发&#xff0c;数据库为SQLServer2008&#x…