From 460bd4f9aa9225fbf25175b7287f7debfc87c9c6 Mon Sep 17 00:00:00 2001
From: xiaoxie <hotcoffie@163.com>
Date: 星期五, 05 十一月 2021 20:02:58 +0800
Subject: [PATCH] 尝试docker-compose启动

---
 /dev/null                 |   97 ------------------------
 docker/docker-compose.yml |   34 ++------
 docker/wvp/Dockerfile     |   88 +++++++++++++++++----
 3 files changed, 79 insertions(+), 140 deletions(-)

diff --git a/docker/assist/Dockerfile b/docker/assist/Dockerfile
deleted file mode 100644
index c64775d..0000000
--- a/docker/assist/Dockerfile
+++ /dev/null
@@ -1,26 +0,0 @@
-FROM openjdk:11-jre-buster AS build
-ARG DEBIAN_FRONTEND=noninteractive
-RUN apt-get update && \
-        DEBIAN_FRONTEND="noninteractive" && \
-        apt-get install -y --no-install-recommends git maven && \
-        cd /home && \
-        git clone https://gitee.com/18010473990/maven.git && \
-        cp maven/settings.xml /usr/share/maven/conf/ && \
-        git clone https://gitee.com/xieyu1989/wvp-pro-assist.git &&\
-        cd /home/wvp-pro-assist
-        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-docker.yml /opt/assist/conf/application.yml
-
-FROM ubuntu:20.04
-ARG DEBIAN_FRONTEND=noninteractive
-EXPOSE 18081/tcp
-RUN apt-get update && \
-        DEBIAN_FRONTEND="noninteractive" && \
-        apt-get install -y --no-install-recommends openjdk-11-jre-headless ca-certificates  ffmpeg && \
-        apt-get autoremove -y && \
-        apt-get clean -y && \
-        rm -rf /var/lib/apt/lists/*dic
-COPY --from=build /opt /opt
-WORKDIR /opt/wvp
-CMD ["java", "-jar","*.jar","--spring.config.location=/opt/assist/conf/application.yml"]
diff --git a/docker/docker-compose.yml b/docker/docker-compose.yml
index 8c6c176..6fa43ce 100644
--- a/docker/docker-compose.yml
+++ b/docker/docker-compose.yml
@@ -9,37 +9,23 @@
     environment:
       TZ: "Asia/Shanghai"
     command: redis-server /etc/redis/redis_default.conf --appendonly yes
-  zlm:
-    image: panjjo/zlmediakit
+  wvp:
+    build:
+      context: ./wvp
     restart: always
-    volumes:
-      - ../video:/home/lin/server/ZLMediaKit/release/linux/Debug/www/record/
     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"
-    environment:
-      TZ: "Asia/Shanghai"
-  assist:
-    build:
-      context: ./assist
-    restart: always
     volumes:
-      - ./conf:/opt/assist/conf
-      - ../video:/home/lin/server/ZLMediaKit/release/linux/Debug/www/record/
+      - ./video:/opt/media/www/record/
     environment:
       TZ: "Asia/Shanghai"
-  wvp:
-    build:
-      context: ./wvp
-    restart: always
-    volumes:
-      - ./conf:/opt/wvp/conf
-    ports:
-      - "5060:5060"
-      - "5060:5060/udp"
-      - "18080:18080"
-    environment:
-      TZ: "Asia/Shanghai"
+      WVP_HOST: 172.18.0.61
+    depends_on:
+      - redis
diff --git a/docker/wvp/Dockerfile b/docker/wvp/Dockerfile
index 4278c9f..334c559 100644
--- a/docker/wvp/Dockerfile
+++ b/docker/wvp/Dockerfile
@@ -1,24 +1,74 @@
 FROM ubuntu:20.04 AS build
-RUN apt-get update && \
-    DEBIAN_FRONTEND="noninteractive" && \
-    apt-get install -y --no-install-recommends openjdk-11-jre-headless git maven nodejs npm &&\
-    cd /home &&\
-    git clone https://gitee.com/18010473990/maven.git && \
-    cp maven/settings.xml /usr/share/maven/conf/ && \
-    git clone https://gitee.com/xieyu1989/wvp-GB28181.git && \
-    cd /home/wvp-GB28181/web_src && \
-    npm install && \
-    npm run build && \
-    mkdir -p /opt/wvp/config && \
-    cd /home/wvp-GB28181 && \
-    mvn clean package -Dmaven.test.skip=true && \
-    cp src/main/resources/application-docker.yml /opt/wvp/conf/application.yml && \
-    cp target/wvp*.jar /opt/wvp/
 
-FROM openjdk:11-jre-buster
+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 && \
+
+        cd /home && \
+        git clone https://gitee.com/18010473990/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 --depth=1 https://gitee.com/xia-chu/ZLMediaKit && \
+        mkdir -p /opt/wvp/config /opt/assist/config /opt/media/www/record && \
+
+        cd /home/wvp-GB28181/web_src && \
+        npm install && \
+        npm run build && \
+
+        cd /home/wvp-GB28181 && \
+        mvn clean package -Dmaven.test.skip=true && \
+        cp /home/wvp-GB28181/target/*.jar /opt/wvp/ && \
+        cp /home/wvp-GB28181/src/main/resources/application-dev.yml /opt/wvp/config/application.yml && \
+
+        cd /home/wvp-pro-assist && \
+        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 && \
+
+        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 && \
+
+        cd /opt/wvp && \
+        echo '#!/bin/bash' > run.sh && \
+        echo 'echo ${WVP_IP}' >> run.sh && \
+        echo 'echo ${WVP_CONFIG}' >> run.sh && \
+        echo 'redis-server --daemonize yes --bind 0.0.0.0' >> run.sh && \
+        echo 'cd /opt/assist' >> run.sh && \
+        echo 'nohup java -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 -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:5060/tcp
-EXPOSE 5060:5060/udp
+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
+
+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 ["java", "-jar","*.jar","--spring.config.location=/opt/wvp/conf/application.yml"]
+CMD ["sh", "run.sh"]
diff --git a/docker/zlm/Dockerfile b/docker/zlm/Dockerfile
deleted file mode 100644
index ce3b649..0000000
--- a/docker/zlm/Dockerfile
+++ /dev/null
@@ -1,63 +0,0 @@
-FROM ubuntu:18.04 AS build
-#shell,rtmp,rtsp,rtsps,http,https,rtp
-EXPOSE 9000/tcp
-EXPOSE 1935/tcp
-EXPOSE 554/tcp
-EXPOSE 322/tcp
-EXPOSE 80/tcp
-EXPOSE 443/tcp
-EXPOSE 10000/udp
-EXPOSE 10000/tcp
-
-RUN apt-get update && \
-         DEBIAN_FRONTEND="noninteractive" \
-         apt-get install -y --no-install-recommends \
-         build-essential \
-         cmake \
-         git \
-         curl \
-         vim \
-         ca-certificates \
-         tzdata \
-         libssl-dev \
-         libmysqlclient-dev \
-         libx264-dev \
-         libfaac-dev \
-         libmp4v2-dev && \
-         apt-get autoremove -y && \
-         apt-get clean -y && \
-    rm -rf /var/lib/apt/lists/*
-
-RUN mkdir -p /opt/media
-
-WORKDIR /opt/media
-RUN git clone --depth=1 https://github.com/xia-chu/ZLMediaKit && \
-    cd ZLMediaKit && git submodule update --init --recursive && \
-    mkdir -p build release/linux/Release/
-
-WORKDIR /opt/media/ZLMediaKit/build
-RUN cmake -DCMAKE_BUILD_TYPE=Release .. && \
-    make
-
-FROM ubuntu:18.04
-LABEL maintainer "Gemfield <gemfield@civilnet.cn>"
-
-RUN apt-get update && \
-         DEBIAN_FRONTEND="noninteractive" \
-         apt-get install -y --no-install-recommends \
-         vim \
-         ca-certificates \
-         tzdata \
-         libssl-dev \
-         libx264-dev \
-         libfaac-dev \
-         ffmpeg \
-         libmp4v2-dev && \
-         apt-get autoremove -y && \
-         apt-get clean -y && \
-    rm -rf /var/lib/apt/lists/*
-
-WORKDIR /opt/media/bin/
-COPY --from=build /opt/media/ZLMediaKit/release/linux/Release/MediaServer /opt/media/bin/MediaServer
-ENV PATH /opt/media/bin:$PATH
-CMD MediaServer
diff --git a/src/main/resources/application-docker.yml b/src/main/resources/application-docker.yml
deleted file mode 100644
index ba59e68..0000000
--- a/src/main/resources/application-docker.yml
+++ /dev/null
@@ -1,97 +0,0 @@
-spring:
-    # REDIS鏁版嵁搴撻厤缃�
-    redis:
-        # [蹇呴』淇敼] Redis鏈嶅姟鍣↖P, REDIS瀹夎鍦ㄦ湰鏈虹殑,浣跨敤127.0.0.1
-        host: redis
-        # [蹇呴』淇敼] 绔彛鍙�
-        port: 6379
-        # [鍙�塢 鏁版嵁搴� DB
-        database: 6
-        # [鍙�塢 璁块棶瀵嗙爜,鑻ヤ綘鐨剅edis鏈嶅姟鍣ㄦ病鏈夎缃瘑鐮侊紝灏变笉闇�瑕佺敤瀵嗙爜鍘昏繛鎺�
-        password: root
-        # [鍙�塢 瓒呮椂鏃堕棿
-        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鐩戝惉鐨凥TTP绔彛, 缃戦〉鍜屾帴鍙h皟鐢ㄩ兘鏄繖涓鍙�
-server:
-    port: 18080
-
-# 浣滀负28181鏈嶅姟鍣ㄧ殑閰嶇疆
-sip:
-    # [蹇呴』淇敼] 鏈満鐨処P
-    ip: ${WVP_HOST:127.0.0.1}
-    # [鍙�塢 28181鏈嶅姟鐩戝惉鐨勭鍙�
-    port: 5060
-    # 鏍规嵁鍥芥爣6.1.2涓瀹氾紝domain瀹滈噰鐢↖D缁熶竴缂栫爜鐨勫墠鍗佷綅缂栫爜銆傚浗鏍囬檮褰旸涓畾涔夊墠8浣嶄负涓績缂栫爜锛堢敱鐪佺骇銆佸競绾с�佸尯绾с�佸熀灞傜紪鍙风粍鎴愶紝鍙傜収GB/T 2260-2007锛�
-    # 鍚庝袱浣嶄负琛屼笟缂栫爜锛屽畾涔夊弬鐓ч檮褰旸.3
-    # 3701020049鏍囪瘑灞变笢娴庡崡鍘嗕笅鍖� 淇℃伅琛屼笟鎺ュ叆
-    # [鍙�塢
-    domain: 6101130049
-    # [鍙�塢
-    id: 61011300490000000001
-    # [鍙�塢 榛樿璁惧璁よ瘉瀵嗙爜锛屽悗缁墿灞曚娇鐢ㄨ澶囧崟鐙瘑鐮�, 绉婚櫎瀵嗙爜灏嗕笉杩涜鏍¢獙
-    password: admin123
-
-#zlm 榛樿鏈嶅姟鍣ㄩ厤缃�
-media:
-    # [蹇呴』淇敼] zlm鏈嶅姟鍣ㄧ殑鍐呯綉IP
-    ip: zlm
-    # [蹇呴』淇敼] zlm鏈嶅姟鍣ㄧ殑http.port
-    http-port: 80
-    # [鍙�塢 zlm鏈嶅姟鍣ㄧ殑hook.admin_params=secret
-    secret: 035c73f7-bb6b-4889-a715-d9eb2d1925cc
-    # 鍚敤澶氱鍙fā寮�, 澶氱鍙fā寮忎娇鐢ㄧ鍙e尯鍒嗘瘡璺祦锛屽吋瀹规�ф洿濂姐�� 鍗曠鍙d娇鐢ㄦ祦鐨剆src鍖哄垎锛� 鐐规挱瓒呮椂寤鸿浣跨敤澶氱鍙f祴璇�
-    rtp:
-        # [鍙�塢 鏄惁鍚敤澶氱鍙fā寮�, 寮�鍚悗浼氬湪portRange鑼冨洿鍐呴�夋嫨绔彛鐢ㄤ簬濯掍綋娴佷紶杈�
-        enable: true
-        # [鍙�塢 鍦ㄦ鑼冨洿鍐呴�夋嫨绔彛鐢ㄤ簬濯掍綋娴佷紶杈�,
-        port-range: 30000,30500 # 绔彛鑼冨洿
-        # [鍙�塢 鍥芥爣绾ц仈鍦ㄦ鑼冨洿鍐呴�夋嫨绔彛鍙戦�佸獟浣撴祦,
-        send-port-range: 30000,30500 # 绔彛鑼冨洿
-    # 褰曞儚杈呭姪鏈嶅姟锛� 閮ㄧ讲姝ゆ湇鍔″彲浠ュ疄鐜皕lm褰曞儚鐨勭鐞嗕笌涓嬭浇锛� 0 琛ㄧず涓嶄娇鐢�
-    record-assist-port: 18081
-
-# [鍙�塢 鏃ュ織閰嶇疆, 涓�鑸笉闇�瑕佹敼
-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@"

--
Gitblit v1.8.0