diff --git a/scripts/deploy_docker.sh b/scripts/deploy_docker.sh index bea209d..666af7b 100644 --- a/scripts/deploy_docker.sh +++ b/scripts/deploy_docker.sh @@ -1,7 +1,7 @@ #!/usr/bin/env bash set -euo pipefail ROOT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")/.." && pwd)" -ENV_NAME="${1:-prod}" +ENV_NAME="${1:-test}" IMAGE="marketing-system-data-tool" TAG="$ENV_NAME" PORT="${PORT:-8077}" @@ -11,7 +11,7 @@ if [ ! -f "$ENV_FILE" ] && [ -f "server/.env.$ENV_NAME" ]; then ENV_FILE="server/.env.$ENV_NAME" fi if [ ! -f "$ENV_FILE" ]; then - echo "$ENV_FILE not found" >&2 + echo "示例:server/.env.example" >&2 exit 1 fi docker build -t "$IMAGE:$TAG" -f Dockerfile . @@ -24,13 +24,27 @@ fi if docker ps -a --format '{{.Names}}' | grep -q "^${CID_NAME}$"; then docker rm "$CID_NAME" >/dev/null 2>&1 || true fi -docker run -d \ - --name "$CID_NAME" \ - --restart unless-stopped \ - --env APP_ENV="$ENV_NAME" \ - --env-file "$ENV_FILE" \ - -p "$PORT:8077" \ - -v "$ROOT_DIR/storage/export:/app/storage/export" \ - -v "$ROOT_DIR/log:/app/log" \ - "$IMAGE:$TAG" +CONFIG_PATH="$ROOT_DIR/server/config.$ENV_NAME.yaml" +if [ -f "$CONFIG_PATH" ]; then + docker run -d \ + --name "$CID_NAME" \ + --restart unless-stopped \ + --env APP_ENV="$ENV_NAME" \ + --env-file "$ENV_FILE" \ + -p "$PORT:8077" \ + -v "$ROOT_DIR/storage/export:/app/storage/export" \ + -v "$ROOT_DIR/log:/app/log" \ + -v "$CONFIG_PATH:/app/server/config.$ENV_NAME.yaml:ro" \ + "$IMAGE:$TAG" +else + docker run -d \ + --name "$CID_NAME" \ + --restart unless-stopped \ + --env APP_ENV="$ENV_NAME" \ + --env-file "$ENV_FILE" \ + -p "$PORT:8077" \ + -v "$ROOT_DIR/storage/export:/app/storage/export" \ + -v "$ROOT_DIR/log:/app/log" \ + "$IMAGE:$TAG" +fi echo "container: $CID_NAME image: $IMAGE:$TAG port: $PORT"