头图

GB28181-WVP-PRO公网部署(centos7+)wvp和zml在同一个服务器(不使用docker部署)--保姆级

概要

` 提示:网上centos,wvp+zml公网部署的文章比较少
因公司需要,自己花了两天左右时间在公网部署了wvp+zml平台,现在整体记录一下具体流程`

1.购买centos7服务器

` 提示:这里我也重新购买一个服务器和你们一样从零搭建确保大家和我一样都可以搭建成功
`
` (如果自己的服务器是双核处理器2.5G内存,里面在执行安装ZLMediaKit时候需要1个小时,最好是配置好一些不然中途很浪费时间)
`

服务器版本
centos7.6

1.
在这里插入图片描述
2.
在这里插入图片描述
3.
在这里插入图片描述
4.
在这里插入图片描述
5.创建成功
创建成功

  • 服务器创建成功之后>>>在window上测试自己能否ping通自己的服务器
    在这里插入图片描述
    如果自己是轻量级服务器或者其他原因ping不同自己的公网ip地址这时候需要在腾讯云里面的安全组设置一下
    在这里插入图片描述
    6
  • 公网地址:119.45.105.210 root 密码:asd123456.
    <<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
    <<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
    <<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
    <<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
    <<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
    <<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>

    2.使用Xshell连接自己的云服务

    1.
    在这里插入图片描述
    2.
    在这里插入图片描述
    3.
    密码登录
    4.

  • cat /etc/centos-release
    终端看到CentOS Linux release 7.6.1810 (Core) 这样的信息表明连接成功
    在这里插入图片描述
    <<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
    <<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
    <<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
    <<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
    <<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
    <<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>

    3.安装ZLMediaKit

  • 参考文章
  • https://blog.51cto.com/mengix/2452395
  • https://github.com/ZLMediaKit/ZLMediaKit/wiki/%E5%BF%AB%E9%80%9F%E5%BC%80%E5%A7%8B
    1.ZLMediaKit---初始化
    在这里插入图片描述
    安装ZLMediaKit前先安装git
    sudo yum update
    sudo yum install git
    git --version
    在这里插入图片描述
    安装好git之后这时候需要创建自己使用的目录 方便管理这里使用自己穿件的test目录
    clear
    cd ..
    mkdir test
    cd test
    在这里插入图片描述

国内用户推荐从同步镜像网站gitee下载 在test目录下执行下面指令
clear
git clone --depth 1 https://gitee.com/xia-chu/ZLMediaKit
cd ZLMediaKit
在这里插入图片描述
千万不要忘记执行这句命令
git submodule update --init
2.安装gcc和gcc-c++ 编译器
在这里插入图片描述
sudo yum -y install gcc
sudo yum -y install gcc-c++
虽然gcc和gcc-c++ 已经存在但后续安装cmake时候会不起作用需要安装版本更高一些的
如果使用的乌班图这里就很简单版本高一些的乌班图系统自带的gcc和gcc-c++ 就很高了
在这里插入图片描述
在这里插入图片描述
3.安装cmake
sudo yum -y install cmake
这里安装cmake时候系统已经存在cmake,这里的cmake版本也低后续也需要进行版本升级
在这里插入图片描述

<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>

4.安装ZLMediaKit依赖库

在这里插入图片描述
先安装这些我自己只安装了ffmpeg>>自己系统要慢的话就只安装openssl后续需要什么在安装什么
除了openssl,其他其实都可以不安装

  • 1.安装ffmpeg

yum install openssl-devel ffmpeg ffmpeg-devel
sudo yum install libssl-dev
sudo yum install libsdl-dev
sudo yum install libavcodec-dev
sudo yum install libavutil-dev
安装ffmeng报错时候执行这段逻辑
在这里插入图片描述

sudo yum install https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm
sudo yum install https://li.nux.ro/download/nux/dextop/el7/x86_64/nux-dextop-release-0-5.el7.nux.noarch.rpm
yum install  openssl-devel ffmpeg ffmpeg-devel

<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
安装其他依赖时候报错No package libssl-dev available.(试了一下没解决这些问题>>等后续我在看看,这里不是很重要不影响部署)
在这里插入图片描述
No package libssl-dev available.执行下面逻辑
安装libsdl-dev(先执行 执行之后再执行yum install openssl-devel时候会显示openssl-devel-1.0.2k-26.el7_9.x86_64 already那)
yum install SDL-devel
安装libssl-dev
yum install openssl-devel
sudo yum install epel-release

  • 2.安装openssl
    创建目录
mkdir openssl
cd /openssl

在这里插入图片描述
这里比较费时间 指令一个一个执行

wget https://www.openssl.org/source/openssl-1.1.1k.tar.gz
tar -xvzf openssl-1.1.1k.tar.gz
yum install -y zlib zlib-devel perl-CPAN
cd openssl-1.1.1k
mkdir -p /usr/local/openssl
./config shared --openssldir=/openssl/openssl-1.1.1k --prefix=/usr/local/openssl
make && make install
echo "/usr/local/lib64/" >> /etc/ld.so.conf
echo "/usr/local/openssl/lib" >> /etc/ld.so.conf
ldconfig
ln -s /usr/local/openssl/bin/openssl  /usr/local/bin/openssl # 替换系统openssl,非必须
sudo yum install gcc-c++ openssl-devel jsoncpp-devel  # 非必须
openssl version -a

在这里插入图片描述
这时候我们编译一下ZLMediaKit
如果ubuntu是新系统的话这里逻辑应该可以走完 ---centos在执行cmake ..这一步的时候就会提示cmake版本太低

cd ..
cd ..
cd ZLMediaKit
mkdir build
cd build
#macOS下可能需要这样指定openss路径:cmake .. -DOPENSSL_ROOT_DIR=/usr/local/Cellar/openssl/1.0.2j/
cmake ..
-----遇到问题 内存不够 ------
1.增加交换空间:
你可以创建一个交换文件来增加可用的虚拟内存。以下是创建 2GB 交换文件的步骤:
sudo fallocate -l 2G /swapfile
sudo chmod 600 /swapfile
sudo mkswap /swapfile
sudo swapon /swapfile

2.确保在 /etc/fstab 中添加以下行,以便在重启时自动挂载:
/swapfile swap swap defaults 0 0

3.降低并行编译数量:
如果你在使用 make -j 进行并行编译,可以尝试使用单线程编译:
make -j1
-----遇到问题 内存不够 ------

make -j4

在这里插入图片描述

  • 4.升级cmake

这里之间执行下面逻辑如果遇到升级问题可以参考这个文章
https://blog.csdn.net/dm569263708/article/details/125198722

mkdir cmake
cd cmake
wget https://cmake.org/files/v3.10/cmake-3.10.0.tar.gz
tar -zxvf cmake-3.10.0.tar.gz
cd cmake-3.10.0
./bootstrap
gmake && gmake install
yum remove cmake
ln -s /usr/local/bin/cmake /usr/bin/cmake
ln -s /usr/local/bin/cpack /usr/bin/cpack
ln -s /usr/local/bin/ctest /usr/bin/ctest
#或者是写环境变量
export PATH=$PATH:/usr/local/bin

5.编译ZLMediaKit
在这里插入图片描述
执行

cmake .. -DENABLE_WEBRTC=true  -DOPENSSL_ROOT_DIR=/usr/local/openssl  -DOPENSSL_LIBRARIES=/usr/local/openssl/lib
cmake ..

在这里插入图片描述
在这里插入图片描述
成功后在执行这个指令make -j4 后面携带的 -j4 >>和你购买的服务器
make -j4命令中,-j4指定了并行编译的线程数。具体来说,-j4表示同时启动4个编译任务,这样可以加快编译速度,特别是在多核处理器系统上。通常,在make命令中使用-j参数可以指定并行编译的线程数,例如-j4表示使用4个线程进行编译。您可以根据您的系统性能和实际情况来调整这个数字,以获得最佳的编译效率
如果编译时候遇到内存不够可以使用这个方式解决
-----------------------------------------------遇到问题 内存不够 ------------------------------------------
1.增加交换空间:
你可以创建一个交换文件来增加可用的虚拟内存。以下是创建 2GB 交换文件的步骤:
sudo fallocate -l 2G /swapfile
sudo chmod 600 /swapfile
sudo mkswap /swapfile
sudo swapon /swapfile

2.确保在 /etc/fstab 中添加以下行,以便在重启时自动挂载:
/swapfile swap swap defaults 0 0

3.降低并行编译数量:
如果你在使用 make -j 进行并行编译,可以尝试使用单线程编译:
make -j1
-----------------------------------------------遇到问题 内存不够 ------------------------------------------
这里时候表示编译成功
在这里插入图片描述
!!!!编译成功后文件不在build这里在[root@VM-0-6-centos ZLMediaKit]# cd release/linux/Debug/
在这里插入图片描述
这时候我们尝试运行一下看看编译的文件是否成功---成功后我们还需要修改config.ini的内容
恭喜大家 弄到这里看到页面是这个样子表示关于zml的这些已经弄的成功了
在这里插入图片描述

<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>

5.ZLMediaKit文件配置

!!!!!!!!!!!!!!下面关于配置配置表示很重要!!!!!
设置文章可以参考这个

https://mp.weixin.qq.com/s?__biz=MzkwNzIxMTExNQ==&mid=2247483985&idx=1&sn=2f21789f8a90ee311a33bc924765dc53&chksm=c0ddfa55f7aa73436007c03eedac21690e051337d547b549a2d120287f0f60772da7b49bab95&cur_album_id=3378104839527890948&scene=190#rd

在这里插入图片描述
具体需要什么配置看我参考文章就行了我把自己配置好的之间贴在这里你们直接复制拿去用就可以了

; auto-generated by mINI class {

[api]
apiDebug=1
defaultSnap=./www/logo.png
downloadRoot=./www
secret=LvPAcRx8EtiLnDvol5RPOz8rWd39SVdH
snapRoot=./www/snap/

[cluster]
origin_url=
retry_count=3
timeout_sec=15

[ffmpeg]
bin=/usr/bin/ffmpeg
cmd=%s -re -i %s -c:a aac -strict -2 -ar 44100 -ab 48k -c:v libx264 -f flv %s
log=./ffmpeg/ffmpeg.log
restart_sec=0
snap=%s -rtsp_transport tcp -i %s -y -f mjpeg -frames:v 1 %s

[general]
broadcast_player_count_changed=0
check_nvidia_dev=1
enableVhost=0
enable_ffmpeg_log=0
flowThreshold=1024
listen_ip=::
maxStreamWaitMS=15000
mediaServerId=H5NVR
mergeWriteMS=0
resetWhenRePlay=1
streamNoneReaderDelayMS=20000
unready_frame_cache=100
wait_add_track_ms=3000
wait_track_ready_ms=10000

[hls]
broadcastRecordTs=0
deleteDelaySec=10
fastRegister=0
fileBufSize=65536
segDelay=0
segDur=2
segKeep=0
segNum=3
segRetain=5

[hook]
alive_interval=10.0
enable=0
on_flow_report=
on_http_access=
on_play=
on_publish=
on_record_mp4=
on_record_ts=
on_rtp_server_timeout=
on_rtsp_auth=
on_rtsp_realm=
on_send_rtp_stopped=
on_server_exited=
on_server_keepalive=
on_server_started=
on_shell_login=
on_stream_changed=
on_stream_none_reader=
on_stream_not_found=
retry=1
retry_delay=3.0
stream_changed_schemas=rtsp/rtmp/fmp4/ts/hls/hls.fmp4
timeoutSec=10

[http]
allow_cross_domains=1
allow_ip_range=
charSet=utf-8
dirMenu=1
forbidCacheSuffix=
forwarded_ip_header=
keepAliveSecond=30
maxReqSize=40960
notFound=<html><head><title>404 Not Found</title></head><body bgcolor="white"><center><h1>您访问的资源不存在!</h1></center><hr><center>ZLMediaKit(git hash:ab22cac/%aI,branch:master,build time:2024-09-09T13:10:47)</center></body></html>
port=6080
rootPath=./www
sendBufSize=65536
sslport=443
virtualPath=

[multicast]
addrMax=239.255.255.255
addrMin=239.0.0.0
udpTTL=64

[protocol]
add_mute_audio=1
auto_close=0
continue_push_ms=3000
enable_audio=1
enable_fmp4=1
enable_hls=1
enable_hls_fmp4=0
enable_mp4=0
enable_rtmp=1
enable_rtsp=1
enable_ts=1
fmp4_demand=0
hls_demand=0
hls_save_path=./www
modify_stamp=2
mp4_as_player=0
mp4_max_second=3600
mp4_save_path=./www
paced_sender_ms=0
rtmp_demand=0
rtsp_demand=0
ts_demand=0

[record]
appName=record
enableFmp4=0
fastStart=0
fileBufSize=65536
fileRepeat=0
sampleMS=500

[rtc]
externIP=
maxRtpCacheMS=5000
maxRtpCacheSize=2048
max_bitrate=0
min_bitrate=0
nackIntervalRatio=1.0
nackMaxCount=15
nackMaxMS=3000
nackMaxSize=2048
nackRtpSize=8
port=8000
preferredCodecA=PCMA,PCMU,opus,mpeg4-generic
preferredCodecV=H264,H265,AV1,VP9,VP8
rembBitRate=0
start_bitrate=0
tcpPort=8000
timeoutSec=15

[rtmp]
directProxy=1
enhanced=0
handshakeSecond=15
keepAliveSecond=15
port=1935
sslport=0

[rtp]
audioMtuSize=600
h264_stap_a=1
lowLatency=0
rtpMaxSize=10
videoMtuSize=1400

[rtp_proxy]
dumpDir=
gop_cache=1
h264_pt=98
h265_pt=99
opus_pt=100
port=10000
port_range=50000-50300
ps_pt=96
rtp_g711_dur_ms=100
timeoutSec=15
udp_recv_socket_buffer=4194304

[rtsp]
authBasic=0
directProxy=1
handshakeSecond=15
keepAliveSecond=15
lowLatency=0
port=554
rtpTransportType=-1
sslport=0

[shell]
maxReqSize=1024
port=0

[srt]
latencyMul=4
pktBufSize=8192
port=9000
timeoutSec=5

; } ---

修改配置后重新运行
在这里插入图片描述
这里重要配置我截图下来
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>

6.docker安装mysql和redis

docker安装mysql和redis用docker安装mysql需要注意一下(不是很稳定)不想使用docker安装 那就自己手动安装
网上手动安装mysql和redis案例非常多就不在演示了,这里我用docker安装
1.安装新版docker

sudo yum remove docker docker-client docker-client-latest docker-common docker-latest docker-latest-logrotate docker-logrotate docker-engine
sudo yum install -y yum-utils device-mapper-persistent-data lvm2
yum-config-manager --add-repo   http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
sudo yum install docker-ce docker-ce-cli containerd.io
sudo systemctl enable docker
sudo systemctl start docker
sudo docker --version

启动Docker服务
安装完成后,使用下面的命令来启动 docker 服务,并将其设置为开机启动:

service docker start
chkconfig docker on

测试Docker是否安装成功
docker version
设置国内镜像
vi /etc/docker/daemon.json

添加后

{
    "registry-mirrors": ["https://mirror.ccs.tencentyun.com"],
    "live-restore": true
}

在这里插入图片描述
依次执行以下命令,重新启动 Docker 服务。
systemctl daemon-reload
service docker restart

检查是否生效
docker info
在这里插入图片描述
Docker Compose的安装

curl -L https://github.com/docker/compose/releases/download/1.28.6/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose

这里下载过慢建议进行手动安装-安装目录我放在文章末尾
cd /usr/local/bin
xftp传输到当前目录
在这里插入图片描述
将可执行权限应用于二进制文件:
sudo chmod +x /usr/local/bin/docker-compose

docker-compose --version
在这里插入图片描述
安装好docker和docker-compose之后我们现在安装mysql和redis
使用.sh文件脚本进行安装
这里 mysql 密码是asd123456. 默认端口
这里redis 密码是 123456 默认端口
在这里插入图片描述

执行脚本
chmod 777 env-install.sh
./env-install.sh
在这里插入图片描述
在这里插入图片描述
docker ps
在这里插入图片描述
到这里展示这些表示安装完成>>>记得在安全组开发端口
在这里插入图片描述
在这里插入图片描述

测试mysql是否连接成功
在这里插入图片描述
测试redis是否连接成功
在这里插入图片描述
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
脚本文件

#!/bin/bash
#Mysql环境安装及配置
docker rm -f $(docker ps -aq)
docker rmi $(docker images -aq)
rm -rf /data
mysql_dir=/data/mysql
redis_dir=/data/redis
minio_dir=/data/minio
rocketmq_dir=/data/rocketmq

mkdir -p $mysql_dir/data
mkdir -p $mysql_dir/conf
#mysql安装文件
echo """version: '3'""">>$mysql_dir/docker-compose.yml
echo """services:""">>$mysql_dir/docker-compose.yml
echo """  mysql:""">>$mysql_dir/docker-compose.yml
echo """    image: mysql:5.7 #mysql版本""">>$mysql_dir/docker-compose.yml
echo """    container_name: mysql""">>$mysql_dir/docker-compose.yml
echo """    volumes:""">>$mysql_dir/docker-compose.yml
echo """      - $mysql_dir/data:/var/lib/mysql""">>$mysql_dir/docker-compose.yml
echo """      - $mysql_dir/conf/my.cnf:/etc/mysql/mysql.conf.d/mysqld.cnf""">>$mysql_dir/docker-compose.yml
echo """    restart: always""">>$mysql_dir/docker-compose.yml
echo """    ports:""">>$mysql_dir/docker-compose.yml
echo """      - 3306:3306""">>$mysql_dir/docker-compose.yml
echo """    environment:""">>$mysql_dir/docker-compose.yml
echo """      MYSQL_ROOT_PASSWORD: asd123456. #root用户密码""">>$mysql_dir/docker-compose.yml
echo """      TZ: Asia/Shanghai""">>$mysql_dir/docker-compose.yml
echo """    command: --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci""">>$mysql_dir/docker-compose.yml
#mysql配置文件
echo """[mysqld]""">>$mysql_dir/conf/my.conf
echo """default-storage-engine=INNODB # 创建新表时将使用的默认存储引擎""">>$mysql_dir/conf/my.conf
echo """character-set-server=utf8mb4      # 设置mysql服务端默认字符集""">>$mysql_dir/conf/my.conf
echo """pid-file        = /var/run/mysqld/mysqld.pid  # pid文件所在目录""">>$mysql_dir/conf/my.conf
echo """socket          = /var/run/mysqld/mysqld.sock # 用于本地连接的socket套接字""">>$mysql_dir/conf/my.conf
echo """datadir         = /var/lib/mysql              # 数据文件存放的目录""">>$mysql_dir/conf/my.conf
echo """symbolic-links=0""">>$mysql_dir/conf/my.conf
echo """sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION # 定义mysql应该支持的sql语法,数据校验等!""">>$mysql_dir/conf/my.conf
echo """# 允许最大连接数""">>$mysql_dir/conf/my.conf
echo """max_connections=200""">>$mysql_dir/conf/my.conf
echo """# 同一局域网内注意要唯一""">>$mysql_dir/conf/my.conf
echo """server-id=3306""">>$mysql_dir/conf/my.conf
echo """# 开启二进制日志功能 & 日志位置存放位置'/var/lib/mysql'""">>$mysql_dir/conf/my.conf
echo """#log-bin=mysql-bin""">>$mysql_dir/conf/my.conf
echo """log-bin=/var/lib/mysql/mysql-bin""">>$mysql_dir/conf/my.conf
echo """# binlog格式""">>$mysql_dir/conf/my.conf
echo """# 1. STATEMENT:基于SQL语句的模式,binlog 数据量小,但是某些语句和函数在复制过程可能导致数据不一致甚至出错;""">>$mysql_dir/conf/my.conf
echo """# 2. MIXED:混合模式,根据语句来选用是 STATEMENT 还是 ROW 模式;""">>$mysql_dir/conf/my.conf
echo """# 3. ROW:基于行的模式,记录的是行的完整变化。安全,但 binlog 会比其他两种模式大很多;""">>$mysql_dir/conf/my.conf
echo """binlog_format=ROW""">>$mysql_dir/conf/my.conf
echo """# FULL:binlog记录每一行的完整变更 MINIMAL:只记录影响后的行""">>$mysql_dir/conf/my.conf
echo """binlog_row_image=FULL""">>$mysql_dir/conf/my.conf
echo """# 日志文件大小""">>$mysql_dir/conf/my.conf
echo """max_binlog_size=100M""">>$mysql_dir/conf/my.conf
echo """# 定义清除过期日志的时间(这里设置为7天)""">>$mysql_dir/conf/my.conf
echo """expire_logs_days=7""">>$mysql_dir/conf/my.conf
echo """# ================= ↑↑↑ mysql主从同步配置end ↑↑↑ =================""">>$mysql_dir/conf/my.conf
echo """[mysql]""">>$mysql_dir/conf/my.conf
echo """default-character-set=utf8mb4""">>$mysql_dir/conf/my.conf
echo """[client]""">>$mysql_dir/conf/my.conf
echo """default-character-set=utf8mb4  # 设置mysql客户端默认字符集""">>$mysql_dir/conf/my.conf
cd $mysql_dir
docker-compose up -d


#Redis安装脚本
#创建挂载目录
mkdir -p $redis_dir
#redis安装文件
echo """version: '3'""">>$redis_dir/docker-compose.yml
echo """services:""">>$redis_dir/docker-compose.yml
echo """  redis:""">>$redis_dir/docker-compose.yml
echo """    image: redis:6.2.6""">>$redis_dir/docker-compose.yml
echo """    container_name: redis""">>$redis_dir/docker-compose.yml
echo """    restart: always""">>$redis_dir/docker-compose.yml
echo """    ports:""">>$redis_dir/docker-compose.yml
echo """      - 6379:6379""">>$redis_dir/docker-compose.yml
echo """    volumes:""">>$redis_dir/docker-compose.yml
echo """      - $redis_dir/redis.conf:/etc/redis/redis.conf""">>$redis_dir/docker-compose.yml
echo """      - $redis_dir/data:/data""">>$redis_dir/docker-compose.yml
echo """      - $redis_dir/logs:/logs""">>$redis_dir/docker-compose.yml
echo '''    command: ["redis-server","/etc/redis/redis.conf"]'''>>$redis_dir/docker-compose.yml
#redis配置文件
echo "protected-mode no">>$redis_dir/redis.conf
echo "port 6379">>$redis_dir/redis.conf
echo "timeout 0">>$redis_dir/redis.conf
echo "#rdb配置">>$redis_dir/redis.conf
echo "save 900 1">>$redis_dir/redis.conf
echo "save 300 10">>$redis_dir/redis.conf
echo "save 60 10000">>$redis_dir/redis.conf
echo "rdbcompression yes">>$redis_dir/redis.conf
echo "dbfilename dump.rdb">>$redis_dir/redis.conf
echo "dir /data">>$redis_dir/redis.conf
echo "appendonly yes">>$redis_dir/redis.conf
echo "appendfsync everysec">>$redis_dir/redis.conf
echo "#设置你的redis密码">>$redis_dir/redis.conf
echo "requirepass 123456">>$redis_dir/redis.conf

cd $redis_dir
docker-compose up -d

<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>

7.编译后端项目wvp

编译后端项目wvp>>>我里我在本地进行打包编译然后在上传到服务器进行运行(你也可以这些步骤在服务器完成>这些网上有很多资料)
使用git进行下载
在这里插入图片描述
在这里插入图片描述
项目下载完之后将数据库进行导入或者运行
在这里插入图片描述
直接执行也行
在这里插入图片描述
在这里插入图片描述
数据库安装好之后先运行后端项目
打开项目
在这里插入图片描述
修改active
在这里插入图片描述
这里先修改mysql和redis
在这里插入图片描述
尝试运行一下
在这里插入图片描述

<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>

8.配置WVP后端文件

可以运行成功这里报错zml失败原因很简单下面zml的配置我们没有进行配置
!!!!!!!!!!下面配置zml!!!很重要
首先先查看自己服务器的内网地址eth0
ip addr
在这里插入图片描述
在查看自己的公网地址
curl ifconfig.me
在这里插入图片描述
这里我们的内网地址是 10.206.0.6
这里我们的外网地址是 1.13.181.240
ZML配置
在这里插入图片描述

这里粘贴我的配置

spring:
  # 设置接口超时时间
  mvc:
    async:
      request-timeout: 20000
  thymeleaf:
    cache: false
  # [可选]上传文件大小限制
  servlet:
    multipart:
      max-file-size: 10MB
      max-request-size: 100MB
  cache:
    type: redis
  # REDIS数据库配置
  redis:
    # [必须修改] Redis服务器IP, REDIS安装在本机的,使用127.0.0.1
    host: 1.13.181.240
    # [必须修改] 端口号
    port: 6379
    # [可选] 数据库 DB
    database: 7
    # [可选] 访问密码,若你的redis服务器没有设置密码,就不需要用密码去连接
    password: 123456
    # [可选] 超时时间
    timeout: 10000
    # mysql数据源
  datasource:
    dynamic:
      primary: master
      datasource:
        master:
          type: com.zaxxer.hikari.HikariDataSource
          driver-class-name: com.mysql.cj.jdbc.Driver
          url: jdbc:mysql://1.13.181.240:3306/wvp?useUnicode=true&characterEncoding=UTF8&rewriteBatchedStatements=true&serverTimezone=PRC&useSSL=false&allowMultiQueries=true
          username: root
          password: asd123456.
          hikari:
            connection-timeout: 20000             # 是客户端等待连接池连接的最大毫秒数
            initialSize: 50                       # 连接池初始化连接数
            maximum-pool-size: 200                # 连接池最大连接数
            minimum-idle: 10                       # 连接池最小空闲连接数
            idle-timeout: 300000                  # 允许连接在连接池中空闲的最长时间(以毫秒为单位)
            max-lifetime: 1200000                 # 是池中连接关闭后的最长生命周期(以毫秒为单位)
#[可选] WVP监听的HTTP端口, 网页和接口调用都是这个端口
server:
  port: 8008
  # [可选] HTTPS配置, 默认不开启
  # CORS配置
  # CORS配置
  cors:
    allowed-origins:
      - http://localhost:8008
      - http://127.0.0.1:8081
      - http://127.0.0.1:8080
      - http://192.168.1.3:8008
      - http://118.195.234.240:8008
      - http://118.195.234.240:8085
    allowed-methods: "GET,POST,PUT,DELETE"
    allowed-headers: "*"
    allow-credentials: true
  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: 10.206.0.6
  # [可选] 28181服务监听的端口
  port: 8116
  # 根据国标6.1.2中规定,domain宜采用ID统一编码的前十位编码。国标附录D中定义前8位为中心编码(由省级、市级、区级、基层编号组成,参照GB/T 2260-2007)
  # 后两位为行业编码,定义参照附录D.3
  # 3701020049标识山东济南历下区 信息行业接入
  # [可选]
  domain: 4101050000
  # [可选]
  id: 41010500002000000001
  # [可选] 默认设备认证密码,后续扩展使用设备单独密码, 移除密码将不进行校验
  password: asd123456
  # 是否存储alarm信息
  alarm: true

#zlm 默认服务器配置
media:
  id: H5NVR
  # [必须修改] zlm服务器的内网IP
  ip: 10.206.0.6
  # [可选] 有公网IP就配置公网IP, 不可用域名
  wan_ip: 1.13.181.240
  # [必须修改] zlm服务器的http.port
  http-port: 6080
  # [可选] 返回流地址时的ip,置空使用 media.ip
  stream-ip: 1.13.181.240
  # [可选] wvp在国标信令中使用的ip,此ip为摄像机可以访问到的ip, 置空使用 media.ip
  sdp-ip: 1.13.181.240
  # [可选] zlm服务器访问WVP所使用的IP, 默认使用127.0.0.1,zlm和wvp没有部署在同一台服务器时必须配置
  hook-ip: 10.206.0.6
  # [必选选] zlm服务器的hook.admin_params=secret
  secret: LvPAcRx8EtiLnDvol5RPOz8rWd39SVdH
  # 启用多端口模式, 多端口模式使用端口区分每路流,兼容性更好。 单端口使用流的ssrc区分, 点播超时建议使用多端口测试
  rtp:
    # [可选] 是否启用多端口模式, 开启后会在portRange范围内选择端口用于媒体流传输
    enable: true
    # [可选] 在此范围内选择端口用于媒体流传输, 必须提前在zlm上配置该属性,不然自动配置此属性可能不成功
    port-range: 50000,50300 # 端口范围
    # [可选] 国标级联在此范围内选择端口发送媒体流,
    send-port-range: 50000,50300 # 端口范围
# [根据业务需求配置]
user-settings:
  # 点播/录像回放 等待超时时间,单位:毫秒
  play-timeout: 180000
  # [可选] 自动点播, 使用固定流地址进行播放时,如果未点播则自动进行点播, 需要rtp.enable=true
  auto-apply-play: true
  # 推流直播是否录制
  record-push-live: true
  # 国标是否录制
  record-sip: true
  # 国标点播 按需拉流, true:有人观看拉流,无人观看释放, false:拉起后不自动释放
  stream-on-demand: true

<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>

9.打包wvp在云端运行

配置好之后进行打包放在云端上面进行运行>>不要在本地进行运行

在这里插入图片描述

[root@VM-0-6-centos test]# ls
cmake  openssl  sh  ZLMediaKit
[root@VM-0-6-centos test]# mkdir java
[root@VM-0-6-centos test]# cd java

在这里插入图片描述
在这里插入图片描述

运行java后端项目
现在开启两个页面
在这里插入图片描述在这里插入图片描述
先启动ZML在启动后端项目
启动Zml
在这里插入图片描述

启动后端项目
安装jdk

yum search java | grep  jdk
yum install -y java-1.8.0-openjdk*
java -version

在这里插入图片描述
启动项目
java -jar wvp-pro-2.7.3-09110615.jar
!!如果第一次启动失败>>>在重新运行一次先运行zml在运行wvp
后端显示
在这里插入图片描述
zml显示
在这里插入图片描述
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>

10.运行前端项目

数据库安装好之后先运行前端项目
npm install
npm run dev
端口改成服务器位置 端口是8008
记得开放端口8008端口
在这里插入图片描述

在这里插入图片描述
用户表密码更改成 e10adc3949ba59abbe56e057f20f883e 123456
在这里插入图片描述
进行登录
在这里插入图片描述
登录成功
在这里插入图片描述

<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>

<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>

11.摄像头接入国标平台

摄像头接入国标平台
在这里插入图片描述
没反应
这里也要开启一些端口
在这里插入图片描述
连接成功
在这里插入图片描述
在这里插入图片描述
视频正常播放恭喜你
在这里插入图片描述

<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>

11.配置webrtc(需要的进行配置)

需要配置的在进行配置不需要配置下面逻辑就不需要走了,直接前端打包部署就可以了
在这里插入图片描述
参考文档 https://blog.csdn.net/cgs1999/article/details/89704359

  859  2024-08-30 11:58:52 mkdir libsrtp
  860  2024-08-30 11:58:55 cd libsrtp/
  861  2024-08-30 11:59:35 ls
  862  2024-08-30 11:59:51 tar -xvzf libsrtp-2.3.0.tar.gz
  863  2024-08-30 11:59:55 cd libsrtp-2.3.0
  864  2024-08-30 12:00:04 ./configure --enable-openssl --with-openssl-dir=/usr/local/openssl
  865  2024-08-30 12:00:10 make 
  866  2024-08-30 12:00:19  sudo make install

在这里插入图片描述
进入zml的build文件夹
执行前可以吧ZLMediaKit全部删除,我自己没删除,大家做到这一步打算开启webrtc时候这里最好删除一下ZLMediaKit,进行重新编译打包
在这里插入图片描述

clear
git clone --depth 1 https://gitee.com/xia-chu/ZLMediaKit
cd ZLMediaKit
#`千万不要忘记执行这句命令`
git submodule update --init
mkdir build
cd build
clear
ls
rm -rf *
ls
cmake .. -DENABLE_WEBRTC=true  -DOPENSSL_ROOT_DIR=/usr/local/openssl  -DOPENSSL_LIBRARIES=/usr/local/openssl/lib

在这里插入图片描述
执行一次cmake .. -DENABLE_WEBRTC=true -DOPENSSL_ROOT_DIR=/usr/local/openssl -DOPENSSL_LIBRARIES=/usr/local/openssl/lib之后需要再执行一遍cmake ..
cmake ..
在这里插入图片描述
这里在执行
make -j4
这里打包完就会多一些webrtc相关一些依赖
注意这里打包完config.ini回复初始样子,文件需要重新进行配置>>配置和上面一样不需要进行修改
在这里插入图片描述
这时候在运行ZML和后端wvp
WebRTC成功展示
webrtc的编码必须是264才可以注意自己的视频编码---我是从265改成了264
在这里插入图片描述

不回显后台运行

wvp nohup java -jar wvp-pro-*.jar
ZML nohup ./MediaServer &

<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>

12.运行报错

jps -l | grep wvp-pro-2.7.3-08300857.jar
ps -ef | grep MediaServer
kill 22995
在这里插入图片描述
在这里插入图片描述
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>

13.项目部署

这里使用nginx进行部署

sudo yum install nginx
sudo systemctl start nginx
sudo systemctl enable nginx

记住开启安全组不要忘记
在这里插入图片描述
不学我这样修改也可以可以修改项目的window.baseUrl = ;
1.
在这里插入图片描述
2.
在这里插入图片描述
打包
npn run build
在这里插入图片描述
test目录下面创建web包用来存放打包文件
在这里插入图片描述
在这里插入图片描述

配置nginx服务
传到本地进行编辑
在这里插入图片描述
对应安全组记得打开

server {
    listen 8085;
    server_name xzchangbei.cn;

    location / {
        root /test/web/static;
        index index.html index.htm;
        try_files $uri $uri/ /index.html;

        # 添加 CORS 头部
        add_header 'Access-Control-Allow-Origin' '*' always;  # 允许所有来源
        add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS' always;  # 允许的请求方法
        add_header 'Access-Control-Allow-Headers' 'Content-Type, Authorization' always;  # 允许的请求头


            #      # 代理 /debug 请求
        location /debug/ {
            proxy_pass http://1.13.181.240:8008;  # 目标 API 地址
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;

        # CORS 设置
        add_header 'Access-Control-Allow-Origin' '*';  # 允许所有域名访问
        add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';  # 允许的方法
        add_header 'Access-Control-Allow-Headers' 'Origin, X-Requested-With, Content-Type, Accept';  # 允许的请求头
        }
     location /api {
        proxy_pass http://1.13.181.240:8008/api;  # 目标 API 地址
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;

        # CORS 设置
        add_header 'Access-Control-Allow-Origin' '*';  # 允许所有域名访问
        add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';  # 允许的方法
        add_header 'Access-Control-Allow-Headers' 'Origin, X-Requested-With, Content-Type, Accept';  # 允许的请求头
        }

        # 处理预检请求
        if ($request_method = OPTIONS) {
            add_header 'Access-Control-Allow-Origin' '*';
            add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
            add_header 'Access-Control-Allow-Headers' 'Content-Type, Authorization';
            add_header 'Content-Length' 0;
            return 204;
        }
    }
}

在这里插入图片描述
更换自己的不用弄错了
重启nginx服务

 1209  2024-08-30 16:23:25 sudo pkill nginx
 1210  2024-08-30 16:23:31 sudo service nginx restart

在这里插入图片描述

<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<-------------------------------------------->>>>>>>>>>>>>>

14.项目测试

写到这里时我换个方式来测试
http://localhost:8081/gb28181/register
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

最后一种测试方式
在这里插入图片描述

ffmpeg -i ./bibi.mp4 -c:v libx264 -bsf:v h264_mp4toannexb -f h264 ./sample.h264
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

15.所需文件获取

回复关键字获取 >>>
wvp
在这里插入图片描述
在这里插入图片描述


不闲聊_Cyc
1 声望0 粉丝