Commit f89672757a48f6ab098f5534cdaf40689b520510

Authored by xiaoxie
1 parent 5070a1fe

1.适配新的gitee地址

2.增加docker-compose相关配置
DOCKERFILE
... ... @@ -28,10 +28,10 @@ RUN apt-get update && \
28 28 cmake curl vim ca-certificates tzdata libmysqlclient-dev redis-server libssl-dev libx264-dev libfaac-dev ffmpeg
29 29 WORKDIR /home
30 30  
31   -RUN git clone https://gitee.com/18010473990/maven.git && \
  31 +RUN git clone https://gitee.com/pan648540858/maven.git && \
32 32 cp maven/settings.xml /usr/share/maven/conf/ && \
33   - git clone https://gitee.com/18010473990/wvp-GB28181.git && \
34   - git clone https://gitee.com/18010473990/wvp-pro-assist.git
  33 + git clone https://gitee.com/pan648540858/wvp-GB28181.git && \
  34 + git clone https://gitee.com/pan648540858/wvp-pro-assist.git
35 35 # 编译前端界面
36 36 WORKDIR /home/wvp-GB28181/web_src
37 37  
... ...
docker/docker-compose.yml 0 → 100644
  1 +version: '3'
  2 +services:
  3 + redis:
  4 + image: redis
  5 + restart: always
  6 + volumes:
  7 + - ./redis/redis.conf:/etc/redis/redis_default.conf
  8 + - ./redis/data/:/data
  9 + environment:
  10 + TZ: "Asia/Shanghai"
  11 + command: redis-server /etc/redis/redis_default.conf --appendonly yes
  12 + wvp:
  13 + build:
  14 + context: ./wvp
  15 + args:
  16 + gitUrl: "https://gitee.com/pan648540858"
  17 + zlmGitUrl: "https://gitee.com/xia-chu/ZLMediaKit"
  18 + restart: always
  19 + ports:
  20 + - "5060:5060"
  21 + - "5060:5060/udp"
  22 + - "18080:18080"
  23 + - "80:80"
  24 + - "10000:10000/tcp"
  25 + - "10000:10000/udp"
  26 + - "30000-30500:30000-30500/tcp"
  27 + - "30000-30500:30000-30500/udp"
  28 + volumes:
  29 + - ./video:/opt/media/www/record/
  30 + - ./logs/wvp:/opt/wvp/logs/
  31 + - ./logs/assist:/opt/assist/logs/
  32 + - ./logs/media:/opt/media/log/
  33 + environment:
  34 + TZ: "Asia/Shanghai"
  35 + # [必须修改] 本机的IP
  36 + WVP_HOST: 172.18.0.61
  37 + WVP_PWD: aseqw_+hiy123
  38 + WVP_DOMAIN: 6101130049
  39 + WVP_ID: 61011300490000000001
  40 + REDIS_HOST: redis
  41 + REDIS_PORT: 6379
  42 + REDIS_DB: 6
  43 + REDIS_PWD: root
  44 + ASSIST_CONFIG:
  45 + WVP_CONFIG:
  46 + depends_on:
  47 + - redis
... ...
docker/redis/redis.conf 0 → 100644
  1 +requirepass root
  2 +bind 0.0.0.0
... ...
docker/wvp/Dockerfile 0 → 100644
  1 +FROM ubuntu:20.04 as build
  2 +
  3 +ARG gitUrl="https://gitee.com/pan648540858"
  4 +ARG zlmGitUrl="https://gitee.com/xia-chu/ZLMediaKit"
  5 +
  6 +RUN export DEBIAN_FRONTEND=noninteractive &&\
  7 + apt-get update && \
  8 + apt-get install -y --no-install-recommends openjdk-11-jre git maven nodejs npm build-essential \
  9 + cmake ca-certificates openssl ffmpeg &&\
  10 + mkdir -p /opt/wvp/config /opt/wvp/heapdump /opt/wvp/config /opt/assist/config /opt/assist/heapdump /opt/media/www/record
  11 +
  12 +RUN cd /home && \
  13 + git clone "${gitUrl}/maven.git" && \
  14 + cp maven/settings.xml /usr/share/maven/conf/
  15 +
  16 +RUN cd /home && \
  17 + git clone "${gitUrl}/wvp-GB28181-pro.git"
  18 +RUN cd /home/wvp-GB28181-pro/web_src && \
  19 + npm install && \
  20 + npm run build
  21 +RUN cd /home/wvp-GB28181-pro && \
  22 + mvn clean package -Dmaven.test.skip=true && \
  23 + cp /home/wvp-GB28181-pro/target/*.jar /opt/wvp/ && \
  24 + cp /home/wvp-GB28181-pro/src/main/resources/application-docker.yml /opt/wvp/config/application.yml
  25 +
  26 +RUN cd /home && \
  27 + git clone "${gitUrl}/wvp-pro-assist.git"
  28 +RUN cd /home/wvp-pro-assist && \
  29 + git reset --hard 58f1a79136a55a7cd1593c95b56ddadcc2225b61 && \
  30 + mvn clean package -Dmaven.test.skip=true && \
  31 + cp /home/wvp-pro-assist/target/*.jar /opt/assist/ && \
  32 + cp /home/wvp-pro-assist/src/main/resources/application-dev.yml /opt/assist/config/application.yml
  33 +
  34 +RUN cd /home && \
  35 + git clone --depth=1 "${zlmGitUrl}"
  36 +RUN cd /home/ZLMediaKit && \
  37 + git submodule update --init --recursive && \
  38 + mkdir -p build release/linux/Release/ &&\
  39 + cd build && \
  40 + cmake -DCMAKE_BUILD_TYPE=Release .. && \
  41 + make -j4 && \
  42 + rm -rf ../release/linux/Release/config.ini && \
  43 + cp -r ../release/linux/Release/* /opt/media
  44 +
  45 +RUN cd /opt/wvp && \
  46 + echo '#!/bin/bash' > run.sh && \
  47 + echo 'echo ${WVP_IP}' >> run.sh && \
  48 + echo 'echo ${WVP_CONFIG}' >> run.sh && \
  49 + echo 'cd /opt/assist' >> run.sh && \
  50 + 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 && \
  51 + echo 'nohup /opt/media/MediaServer -d -m 3 &' >> run.sh && \
  52 + echo 'cd /opt/wvp' >> run.sh && \
  53 + 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 && \
  54 + chmod +x run.sh
  55 +
  56 +FROM ubuntu:20.04
  57 +
  58 +EXPOSE 18080/tcp
  59 +EXPOSE 5060/tcp
  60 +EXPOSE 5060/udp
  61 +EXPOSE 6379/tcp
  62 +EXPOSE 18081/tcp
  63 +EXPOSE 80/tcp
  64 +EXPOSE 1935/tcp
  65 +EXPOSE 554/tcp
  66 +EXPOSE 554/udp
  67 +EXPOSE 30000-30500/tcp
  68 +EXPOSE 30000-30500/udp
  69 +
  70 +ENV LC_ALL zh_CN.UTF-8
  71 +
  72 +RUN export DEBIAN_FRONTEND=noninteractive &&\
  73 + apt-get update && \
  74 + apt-get install -y --no-install-recommends openjdk-11-jre ca-certificates ffmpeg language-pack-zh-hans && \
  75 + apt-get autoremove -y && \
  76 + apt-get clean -y && \
  77 + rm -rf /var/lib/apt/lists/*dic
  78 +
  79 +COPY --from=build /opt /opt
  80 +WORKDIR /opt/wvp
  81 +CMD ["sh", "run.sh"]
... ...
src/main/resources/application-docker.yml 0 → 100644
  1 +spring:
  2 + # REDIS数据库配置
  3 + redis:
  4 + # [必须修改] Redis服务器IP, REDIS安装在本机的,使用127.0.0.1
  5 + host: ${REDIS_HOST:127.0.0.1}
  6 + # [必须修改] 端口号
  7 + port: ${REDIS_PORT:6379}
  8 + # [可选] 数据库 DB
  9 + database: ${REDIS_DB:6}
  10 + # [可选] 访问密码,若你的redis服务器没有设置密码,就不需要用密码去连接
  11 + password: ${REDIS_PWD:}
  12 + # [可选] 超时时间
  13 + timeout: 10000
  14 + # [可选] jdbc数据库配置, 项目使用sqlite作为数据库,一般不需要配置
  15 + datasource:
  16 + # 使用mysql 打开23-28行注释, 删除29-36行
  17 + # name: wvp
  18 + # url: jdbc:mysql://127.0.0.1:3306/wvp?useUnicode=true&characterEncoding=UTF8&rewriteBatchedStatements=true
  19 + # username:
  20 + # password:
  21 + # type: com.alibaba.druid.pool.DruidDataSource
  22 + # driver-class-name: com.mysql.cj.jdbc.Driver
  23 + name: eiot
  24 + url: jdbc:sqlite::resource:wvp.sqlite
  25 + username:
  26 + password:
  27 + type: com.alibaba.druid.pool.DruidDataSource
  28 + driver-class-name: org.sqlite.JDBC
  29 + max-active: 1
  30 + min-idle: 1
  31 +
  32 +# [可选] WVP监听的HTTP端口, 网页和接口调用都是这个端口
  33 +server:
  34 + port: 18080
  35 +
  36 +# 作为28181服务器的配置
  37 +sip:
  38 + # [必须修改] 本机的IP
  39 + ip: ${WVP_HOST:127.0.0.1}
  40 + # [可选] 28181服务监听的端口
  41 + port: ${WVP_PORT:5060}
  42 + # 根据国标6.1.2中规定,domain宜采用ID统一编码的前十位编码。国标附录D中定义前8位为中心编码(由省级、市级、区级、基层编号组成,参照GB/T 2260-2007)
  43 + # 后两位为行业编码,定义参照附录D.3
  44 + # 3701020049标识山东济南历下区 信息行业接入
  45 + # [可选]
  46 + domain: ${WVP_DOMAIN:4401020049}
  47 + # [可选]
  48 + id: ${WVP_ID:44010200492000000001}
  49 + # [可选] 默认设备认证密码,后续扩展使用设备单独密码, 移除密码将不进行校验
  50 + password: ${WVP_PWD:admin123}
  51 +
  52 +#zlm 默认服务器配置
  53 +media:
  54 + # [必须修改] zlm服务器的内网IP
  55 + ip: ${ZLM_HOST:127.0.0.1}
  56 + # [必须修改] zlm服务器的http.port
  57 + http-port: ${ZLM_PORT:80}
  58 + # [可选] zlm服务器的hook.admin_params=secret
  59 + secret: 035c73f7-bb6b-4889-a715-d9eb2d1925cc
  60 + # 启用多端口模式, 多端口模式使用端口区分每路流,兼容性更好。 单端口使用流的ssrc区分, 点播超时建议使用多端口测试
  61 + rtp:
  62 + # [可选] 是否启用多端口模式, 开启后会在portRange范围内选择端口用于媒体流传输
  63 + enable: true
  64 + # [可选] 在此范围内选择端口用于媒体流传输,
  65 + port-range: 30000,30500 # 端口范围
  66 + # [可选] 国标级联在此范围内选择端口发送媒体流,
  67 + send-port-range: 30000,30500 # 端口范围
  68 + # 录像辅助服务, 部署此服务可以实现zlm录像的管理与下载, 0 表示不使用
  69 + record-assist-port: 18081
  70 + sdp-ip: ${sip.ip}
  71 + stream-ip: ${sip.ip}
  72 +# [可选] 日志配置, 一般不需要改
  73 +logging:
  74 + file:
  75 + name: logs/wvp.log
  76 + max-history: 30
  77 + max-size: 10MB
  78 + total-size-cap: 300MB
  79 + level:
  80 + com.genersoft.iot: debug
  81 + com.genersoft.iot.vmp.storager.dao: info
  82 + com.genersoft.iot.vmp.gb28181: info
  83 +
  84 +# [根据业务需求配置]
  85 +user-settings:
  86 + # 推流直播是否录制
  87 + record-push-live: true
  88 + auto-apply-play: false
  89 +
  90 +# 在线文档: swagger-ui(生产环境建议关闭)
  91 +swagger-ui:
  92 + enabled: true
  93 +
  94 +# 版本信息, 不需修改
  95 +version:
  96 + version: "@project.version@"
  97 + description: "@project.description@"
  98 + artifact-id: "@project.artifactId@"
... ...