From f89672757a48f6ab098f5534cdaf40689b520510 Mon Sep 17 00:00:00 2001 From: xiaoxie Date: Wed, 1 Dec 2021 20:28:13 +0800 Subject: [PATCH 1/4] =?UTF-8?q?1.=E9=80=82=E9=85=8D=E6=96=B0=E7=9A=84gitee?= =?UTF-8?q?=E5=9C=B0=E5=9D=80=202.=E5=A2=9E=E5=8A=A0docker-compose?= =?UTF-8?q?=E7=9B=B8=E5=85=B3=E9=85=8D=E7=BD=AE?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- DOCKERFILE | 6 +- docker/docker-compose.yml | 47 +++++++++++ docker/redis/redis.conf | 2 + docker/wvp/Dockerfile | 81 +++++++++++++++++++ src/main/resources/application-docker.yml | 98 +++++++++++++++++++++++ 5 files changed, 231 insertions(+), 3 deletions(-) create mode 100644 docker/docker-compose.yml create mode 100644 docker/redis/redis.conf create mode 100644 docker/wvp/Dockerfile create mode 100644 src/main/resources/application-docker.yml diff --git a/DOCKERFILE b/DOCKERFILE index 28913dab..96bc29bf 100644 --- a/DOCKERFILE +++ b/DOCKERFILE @@ -28,10 +28,10 @@ RUN apt-get update && \ cmake curl vim ca-certificates tzdata libmysqlclient-dev redis-server libssl-dev libx264-dev libfaac-dev ffmpeg WORKDIR /home -RUN git clone https://gitee.com/18010473990/maven.git && \ +RUN git clone https://gitee.com/pan648540858/maven.git && \ cp maven/settings.xml /usr/share/maven/conf/ && \ - git clone https://gitee.com/18010473990/wvp-GB28181.git && \ - git clone https://gitee.com/18010473990/wvp-pro-assist.git + git clone https://gitee.com/pan648540858/wvp-GB28181.git && \ + git clone https://gitee.com/pan648540858/wvp-pro-assist.git # 编译前端界面 WORKDIR /home/wvp-GB28181/web_src diff --git a/docker/docker-compose.yml b/docker/docker-compose.yml new file mode 100644 index 00000000..524356bc --- /dev/null +++ b/docker/docker-compose.yml @@ -0,0 +1,47 @@ +version: '3' +services: + redis: + image: redis + restart: always + volumes: + - ./redis/redis.conf:/etc/redis/redis_default.conf + - ./redis/data/:/data + environment: + TZ: "Asia/Shanghai" + command: redis-server /etc/redis/redis_default.conf --appendonly yes + wvp: + build: + context: ./wvp + args: + gitUrl: "https://gitee.com/pan648540858" + zlmGitUrl: "https://gitee.com/xia-chu/ZLMediaKit" + restart: always + ports: + - "5060:5060" + - "5060:5060/udp" + - "18080:18080" + - "80:80" + - "10000:10000/tcp" + - "10000:10000/udp" + - "30000-30500:30000-30500/tcp" + - "30000-30500:30000-30500/udp" + volumes: + - ./video:/opt/media/www/record/ + - ./logs/wvp:/opt/wvp/logs/ + - ./logs/assist:/opt/assist/logs/ + - ./logs/media:/opt/media/log/ + environment: + TZ: "Asia/Shanghai" + # [必须修改] 本机的IP + WVP_HOST: 172.18.0.61 + WVP_PWD: aseqw_+hiy123 + WVP_DOMAIN: 6101130049 + WVP_ID: 61011300490000000001 + REDIS_HOST: redis + REDIS_PORT: 6379 + REDIS_DB: 6 + REDIS_PWD: root + ASSIST_CONFIG: + WVP_CONFIG: + depends_on: + - redis diff --git a/docker/redis/redis.conf b/docker/redis/redis.conf new file mode 100644 index 00000000..c211f137 --- /dev/null +++ b/docker/redis/redis.conf @@ -0,0 +1,2 @@ +requirepass root +bind 0.0.0.0 diff --git a/docker/wvp/Dockerfile b/docker/wvp/Dockerfile new file mode 100644 index 00000000..ca9ef21e --- /dev/null +++ b/docker/wvp/Dockerfile @@ -0,0 +1,81 @@ +FROM ubuntu:20.04 as build + +ARG gitUrl="https://gitee.com/pan648540858" +ARG zlmGitUrl="https://gitee.com/xia-chu/ZLMediaKit" + +RUN export DEBIAN_FRONTEND=noninteractive &&\ + apt-get update && \ + apt-get install -y --no-install-recommends openjdk-11-jre git maven nodejs npm build-essential \ + cmake ca-certificates openssl ffmpeg &&\ + mkdir -p /opt/wvp/config /opt/wvp/heapdump /opt/wvp/config /opt/assist/config /opt/assist/heapdump /opt/media/www/record + +RUN cd /home && \ + git clone "${gitUrl}/maven.git" && \ + cp maven/settings.xml /usr/share/maven/conf/ + +RUN cd /home && \ + git clone "${gitUrl}/wvp-GB28181-pro.git" +RUN cd /home/wvp-GB28181-pro/web_src && \ + npm install && \ + npm run build +RUN cd /home/wvp-GB28181-pro && \ + mvn clean package -Dmaven.test.skip=true && \ + cp /home/wvp-GB28181-pro/target/*.jar /opt/wvp/ && \ + cp /home/wvp-GB28181-pro/src/main/resources/application-docker.yml /opt/wvp/config/application.yml + +RUN cd /home && \ + git clone "${gitUrl}/wvp-pro-assist.git" +RUN cd /home/wvp-pro-assist && \ + git reset --hard 58f1a79136a55a7cd1593c95b56ddadcc2225b61 && \ + mvn clean package -Dmaven.test.skip=true && \ + cp /home/wvp-pro-assist/target/*.jar /opt/assist/ && \ + cp /home/wvp-pro-assist/src/main/resources/application-dev.yml /opt/assist/config/application.yml + +RUN cd /home && \ + git clone --depth=1 "${zlmGitUrl}" +RUN cd /home/ZLMediaKit && \ + git submodule update --init --recursive && \ + mkdir -p build release/linux/Release/ &&\ + cd build && \ + cmake -DCMAKE_BUILD_TYPE=Release .. && \ + make -j4 && \ + rm -rf ../release/linux/Release/config.ini && \ + cp -r ../release/linux/Release/* /opt/media + +RUN cd /opt/wvp && \ + echo '#!/bin/bash' > run.sh && \ + echo 'echo ${WVP_IP}' >> run.sh && \ + echo 'echo ${WVP_CONFIG}' >> run.sh && \ + echo 'cd /opt/assist' >> run.sh && \ + echo 'nohup java -Xms128m -Xmx256m -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/opt/assist/heapdump/ -jar *.jar --spring.config.location=/opt/assist/config/application.yml --userSettings.record=/opt/media/www/record/ --media.record-assist-port=18081 ${ASSIST_CONFIG} &' >> run.sh && \ + echo 'nohup /opt/media/MediaServer -d -m 3 &' >> run.sh && \ + echo 'cd /opt/wvp' >> run.sh && \ + echo 'java -Xms128m -Xmx256m -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/opt/wvp/heapdump/ -jar *.jar --spring.config.location=/opt/wvp/config/application.yml --media.record-assist-port=18081 ${WVP_CONFIG}' >> run.sh && \ + chmod +x run.sh + +FROM ubuntu:20.04 + +EXPOSE 18080/tcp +EXPOSE 5060/tcp +EXPOSE 5060/udp +EXPOSE 6379/tcp +EXPOSE 18081/tcp +EXPOSE 80/tcp +EXPOSE 1935/tcp +EXPOSE 554/tcp +EXPOSE 554/udp +EXPOSE 30000-30500/tcp +EXPOSE 30000-30500/udp + +ENV LC_ALL zh_CN.UTF-8 + +RUN export DEBIAN_FRONTEND=noninteractive &&\ + apt-get update && \ + apt-get install -y --no-install-recommends openjdk-11-jre ca-certificates ffmpeg language-pack-zh-hans && \ + apt-get autoremove -y && \ + apt-get clean -y && \ + rm -rf /var/lib/apt/lists/*dic + +COPY --from=build /opt /opt +WORKDIR /opt/wvp +CMD ["sh", "run.sh"] diff --git a/src/main/resources/application-docker.yml b/src/main/resources/application-docker.yml new file mode 100644 index 00000000..ff60f5af --- /dev/null +++ b/src/main/resources/application-docker.yml @@ -0,0 +1,98 @@ +spring: + # REDIS数据库配置 + redis: + # [必须修改] Redis服务器IP, REDIS安装在本机的,使用127.0.0.1 + host: ${REDIS_HOST:127.0.0.1} + # [必须修改] 端口号 + port: ${REDIS_PORT:6379} + # [可选] 数据库 DB + database: ${REDIS_DB:6} + # [可选] 访问密码,若你的redis服务器没有设置密码,就不需要用密码去连接 + password: ${REDIS_PWD:} + # [可选] 超时时间 + timeout: 10000 + # [可选] jdbc数据库配置, 项目使用sqlite作为数据库,一般不需要配置 + datasource: + # 使用mysql 打开23-28行注释, 删除29-36行 + # name: wvp + # url: jdbc:mysql://127.0.0.1:3306/wvp?useUnicode=true&characterEncoding=UTF8&rewriteBatchedStatements=true + # username: + # password: + # type: com.alibaba.druid.pool.DruidDataSource + # driver-class-name: com.mysql.cj.jdbc.Driver + name: eiot + url: jdbc:sqlite::resource:wvp.sqlite + username: + password: + type: com.alibaba.druid.pool.DruidDataSource + driver-class-name: org.sqlite.JDBC + max-active: 1 + min-idle: 1 + +# [可选] WVP监听的HTTP端口, 网页和接口调用都是这个端口 +server: + port: 18080 + +# 作为28181服务器的配置 +sip: + # [必须修改] 本机的IP + ip: ${WVP_HOST:127.0.0.1} + # [可选] 28181服务监听的端口 + port: ${WVP_PORT:5060} + # 根据国标6.1.2中规定,domain宜采用ID统一编码的前十位编码。国标附录D中定义前8位为中心编码(由省级、市级、区级、基层编号组成,参照GB/T 2260-2007) + # 后两位为行业编码,定义参照附录D.3 + # 3701020049标识山东济南历下区 信息行业接入 + # [可选] + domain: ${WVP_DOMAIN:4401020049} + # [可选] + id: ${WVP_ID:44010200492000000001} + # [可选] 默认设备认证密码,后续扩展使用设备单独密码, 移除密码将不进行校验 + password: ${WVP_PWD:admin123} + +#zlm 默认服务器配置 +media: + # [必须修改] zlm服务器的内网IP + ip: ${ZLM_HOST:127.0.0.1} + # [必须修改] zlm服务器的http.port + http-port: ${ZLM_PORT:80} + # [可选] 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 + sdp-ip: ${sip.ip} + stream-ip: ${sip.ip} +# [可选] 日志配置, 一般不需要改 +logging: + file: + name: logs/wvp.log + max-history: 30 + max-size: 10MB + total-size-cap: 300MB + level: + com.genersoft.iot: debug + com.genersoft.iot.vmp.storager.dao: info + com.genersoft.iot.vmp.gb28181: info + +# [根据业务需求配置] +user-settings: + # 推流直播是否录制 + record-push-live: true + auto-apply-play: false + +# 在线文档: swagger-ui(生产环境建议关闭) +swagger-ui: + enabled: true + +# 版本信息, 不需修改 +version: + version: "@project.version@" + description: "@project.description@" + artifact-id: "@project.artifactId@" From 0984290ca2a75cf0316c3ca312bf8026b4edcf3e Mon Sep 17 00:00:00 2001 From: xiaoxie Date: Wed, 1 Dec 2021 22:45:38 +0800 Subject: [PATCH 2/4] =?UTF-8?q?=E7=BB=A7=E7=BB=AD=E4=BC=98=E5=8C=96docker?= =?UTF-8?q?=E9=85=8D=E7=BD=AE=EF=BC=9A=201.=E5=90=AF=E5=8A=A8=E5=91=BD?= =?UTF-8?q?=E4=BB=A4=E5=A2=9E=E5=8A=A0ASSIST=5FJVM=5FCONFIG=E5=92=8CWVP=5F?= =?UTF-8?q?JVM=5FCONFIG=E4=B8=A4=E4=B8=AA=E5=AD=97=E6=AE=B5=EF=BC=8C?= =?UTF-8?q?=E6=96=B9=E4=BE=BF=E9=85=8D=E7=BD=AEJVM=E5=8F=82=E6=95=B0=202.?= =?UTF-8?q?=E4=BF=AE=E5=A4=8D=E4=B8=80=E5=A4=84=E9=94=99=E8=AF=AF=EF=BC=8C?= =?UTF-8?q?application.yml=20media.stream-ip=E7=9A=84=E5=80=BC=E5=BA=94?= =?UTF-8?q?=E8=AF=A5=E7=AD=89=E4=BA=8Emedia.ip=E8=80=8C=E4=B8=8D=E6=98=AF?= =?UTF-8?q?=E4=B9=8B=E5=89=8D=E7=9A=84sip.ip?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- docker/docker-compose.yml | 2 ++ docker/wvp/Dockerfile | 4 ++-- src/main/resources/application-docker.yml | 6 +++--- 3 files changed, 7 insertions(+), 5 deletions(-) diff --git a/docker/docker-compose.yml b/docker/docker-compose.yml index 524356bc..3da521a9 100644 --- a/docker/docker-compose.yml +++ b/docker/docker-compose.yml @@ -41,6 +41,8 @@ services: REDIS_PORT: 6379 REDIS_DB: 6 REDIS_PWD: root + ASSIST_JVM_CONFIG: -Xms128m -Xmx256m + WVP_JVM_CONFIG: -Xms128m -Xmx256m ASSIST_CONFIG: WVP_CONFIG: depends_on: diff --git a/docker/wvp/Dockerfile b/docker/wvp/Dockerfile index ca9ef21e..34e3babb 100644 --- a/docker/wvp/Dockerfile +++ b/docker/wvp/Dockerfile @@ -47,10 +47,10 @@ RUN cd /opt/wvp && \ echo 'echo ${WVP_IP}' >> run.sh && \ echo 'echo ${WVP_CONFIG}' >> run.sh && \ echo 'cd /opt/assist' >> run.sh && \ - echo 'nohup java -Xms128m -Xmx256m -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/opt/assist/heapdump/ -jar *.jar --spring.config.location=/opt/assist/config/application.yml --userSettings.record=/opt/media/www/record/ --media.record-assist-port=18081 ${ASSIST_CONFIG} &' >> run.sh && \ + echo 'nohup java ${ASSIST_JVM_CONFIG} -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/opt/assist/heapdump/ -jar *.jar --spring.config.location=/opt/assist/config/application.yml --userSettings.record=/opt/media/www/record/ --media.record-assist-port=18081 ${ASSIST_CONFIG} &' >> run.sh && \ echo 'nohup /opt/media/MediaServer -d -m 3 &' >> run.sh && \ echo 'cd /opt/wvp' >> run.sh && \ - echo 'java -Xms128m -Xmx256m -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/opt/wvp/heapdump/ -jar *.jar --spring.config.location=/opt/wvp/config/application.yml --media.record-assist-port=18081 ${WVP_CONFIG}' >> run.sh && \ + echo 'java ${WVP_JVM_CONFIG} -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/opt/wvp/heapdump/ -jar *.jar --spring.config.location=/opt/wvp/config/application.yml --media.record-assist-port=18081 ${WVP_CONFIG}' >> run.sh && \ chmod +x run.sh FROM ubuntu:20.04 diff --git a/src/main/resources/application-docker.yml b/src/main/resources/application-docker.yml index ff60f5af..e8f2c713 100644 --- a/src/main/resources/application-docker.yml +++ b/src/main/resources/application-docker.yml @@ -8,7 +8,7 @@ spring: # [可选] 数据库 DB database: ${REDIS_DB:6} # [可选] 访问密码,若你的redis服务器没有设置密码,就不需要用密码去连接 - password: ${REDIS_PWD:} + password: ${REDIS_PWD:root} # [可选] 超时时间 timeout: 10000 # [可选] jdbc数据库配置, 项目使用sqlite作为数据库,一般不需要配置 @@ -67,7 +67,7 @@ media: send-port-range: 30000,30500 # 端口范围 # 录像辅助服务, 部署此服务可以实现zlm录像的管理与下载, 0 表示不使用 record-assist-port: 18081 - sdp-ip: ${sip.ip} + sdp-ip: ${media.ip} stream-ip: ${sip.ip} # [可选] 日志配置, 一般不需要改 logging: @@ -85,7 +85,7 @@ logging: user-settings: # 推流直播是否录制 record-push-live: true - auto-apply-play: false + auto-apply-play: true # 在线文档: swagger-ui(生产环境建议关闭) swagger-ui: From 7371db4674c128e73223fdffb8a783c6b05672c2 Mon Sep 17 00:00:00 2001 From: xiaoxie Date: Wed, 1 Dec 2021 22:49:45 +0800 Subject: [PATCH 3/4] =?UTF-8?q?=E4=BF=AE=E5=A4=8D=E4=B8=80=E5=A4=84?= =?UTF-8?q?=E9=94=99=E8=AF=AF=EF=BC=8Capplication.yml=20media.stream-ip?= =?UTF-8?q?=E7=9A=84=E5=80=BC=E5=BA=94=E8=AF=A5=E7=AD=89=E4=BA=8Emedia.ip?= =?UTF-8?q?=E8=80=8C=E4=B8=8D=E6=98=AF=E4=B9=8B=E5=89=8D=E7=9A=84sip.ip?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/resources/application-docker.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/main/resources/application-docker.yml b/src/main/resources/application-docker.yml index e8f2c713..66c45b40 100644 --- a/src/main/resources/application-docker.yml +++ b/src/main/resources/application-docker.yml @@ -67,8 +67,8 @@ media: send-port-range: 30000,30500 # 端口范围 # 录像辅助服务, 部署此服务可以实现zlm录像的管理与下载, 0 表示不使用 record-assist-port: 18081 - sdp-ip: ${media.ip} - stream-ip: ${sip.ip} + sdp-ip: ${sip.ip} + stream-ip: ${media.ip} # [可选] 日志配置, 一般不需要改 logging: file: From a0c7b35e1dc9399698222dc766b71729bfaece6c Mon Sep 17 00:00:00 2001 From: xiaoxie Date: Wed, 1 Dec 2021 22:58:00 +0800 Subject: [PATCH 4/4] =?UTF-8?q?=E4=BF=AE=E5=A4=8D=E4=B8=80=E5=A4=84?= =?UTF-8?q?=E9=94=99=E8=AF=AF=EF=BC=8C=E6=81=A2=E5=A4=8Dapplication.yml=20?= =?UTF-8?q?media.stream-ip=E5=8E=9F=E6=9D=A5=E7=9A=84=E5=80=BC?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/resources/application-docker.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/main/resources/application-docker.yml b/src/main/resources/application-docker.yml index 66c45b40..37c3294f 100644 --- a/src/main/resources/application-docker.yml +++ b/src/main/resources/application-docker.yml @@ -68,7 +68,7 @@ media: # 录像辅助服务, 部署此服务可以实现zlm录像的管理与下载, 0 表示不使用 record-assist-port: 18081 sdp-ip: ${sip.ip} - stream-ip: ${media.ip} + stream-ip: ${sip.ip} # [可选] 日志配置, 一般不需要改 logging: file: