diff --git a/.woodpecker/my-first-workflow.yaml b/.woodpecker/my-first-workflow.yaml index 6eaa53852..a8de02a8f 100644 --- a/.woodpecker/my-first-workflow.yaml +++ b/.woodpecker/my-first-workflow.yaml @@ -65,3 +65,103 @@ steps: # 拉取代码 - echo "✅ 代码拉取完成" + # ========== 3. 生成版本号(依赖prepare:代码拉取完成) ========== + set-version: + image: golang:1.25 + depends_on: [prepare] + commands: + - | + VERSION="v$(git rev-parse --short=8 HEAD)" + echo "BUILD_VERSION=$VERSION" >> "$CI_ENV_FILE" + echo "构建版本号:$VERSION" + echo "✅ 生成版本号:{VERSION" + + # ========== 4. 编译Logic服务(完全参考GitHub Actions编译配置) ========== + build_logic: + image: golang:1.25 + depends_on: [prepare] + environment: + CGO_ENABLED: 0 + GO111MODULE: on + GOSUMDB: off + commands: + - mkdir -p build + - BIN_NAME="logic_${BUILD_VERSION}" + - | + go build -v \ + -p=4 \ + -trimpath \ + -buildvcs=false \ + -ldflags "-s -w -buildid= -extldflags '-static'" \ + -o ./build/${BIN_NAME} \ + ./logic + - | + if [ ! -f ./build/${BIN_NAME} ]; then + echo "❌ 编译失败:产物${BIN_NAME}不存在" + exit 1 + fi + - ls -lh ./build/ + - echo "产物名称:${BIN_NAME}" + - echo "✅ Logic服务编译完成" + + # ========== 5. 拉取部署配置(可并行,依赖prepare确保代码拉取完成) ========== + fetch-deploy-config: # 与build_logic同级,缩进2个空格 + image: alpine:latest # 子元素,缩进4个空格 + depends_on: [prepare] # 子元素,缩进4个空格 + commands: # 子元素,缩进4个空格 + - apk add --no-cache curl jq # commands内的项,缩进6个空格 + - echo "🔧 拉取部署配置:${JSON_CONFIG_URL}" # 缩进6个空格 + - | # 缩进6个空格 + for i in 1 2 3; do + curl -sSL --connect-timeout 10 --max-time 30 "${JSON_CONFIG_URL}" -o /tmp/deploy-config.json && break + echo "⚠️ 第${i}次拉取失败,重试中..." + sleep 2 + done + if [ ! -f /tmp/deploy-config.json ]; then + echo "❌ 拉取JSON配置失败" + exit 1 + fi + - | # 缩进6个空格 + JSON_TYPE=$(jq -r 'type' /tmp/deploy-config.json 2>/dev/null || echo "invalid") + if [ "$JSON_TYPE" = "array" ]; then + REMOTE_HOSTS=$(jq -r '.[].loginaddr' /tmp/deploy-config.json | tr '\n' ',' | sed 's/,$//') + REMOTE_USERS=$(jq -r '.[].user' /tmp/deploy-config.json | tr '\n' ',' | sed 's/,$//') + REMOTE_PASSWORDS=$(jq -r '.[].password' /tmp/deploy-config.json | tr '\n' ',' | sed 's/,$//') + REMOTE_ONLINE_IDS=$(jq -r '.[].online_id' /tmp/deploy-config.json | tr '\n' ',' | sed 's/,$//') + elif [ "$JSON_TYPE" = "object" ]; then + REMOTE_HOSTS=$(jq -r '.loginaddr' /tmp/deploy-config.json) + REMOTE_USERS=$(jq -r '.user' /tmp/deploy-config.json) + REMOTE_PASSWORDS=$(jq -r '.password' /tmp/deploy-config.json) + REMOTE_ONLINE_IDS=$(jq -r '.online_id' /tmp/deploy-config.json) + else + echo "❌ JSON配置格式错误(非数组/对象)" + cat /tmp/deploy-config.json + exit 1 + fi + - | # 缩进6个空格 + if [ -z "$REMOTE_HOSTS" ] || [ -z "$REMOTE_USERS" ]; then + echo "❌ 解析配置失败:服务器/用户名为空" + cat /tmp/deploy-config.json + exit 1 + fi + - echo "✅ 配置解析完成 | 服务器:${REMOTE_HOSTS} | OnlineID:${REMOTE_ONLINE_IDS}" # 缩进6个空格 + - echo "REMOTE_HOSTS=${REMOTE_HOSTS}" >> "$CI_ENV_FILE" # 缩进6个空格 + - echo "REMOTE_USERS=${REMOTE_USERS}" >> "$CI_ENV_FILE" # 缩进6个空格 + - echo "REMOTE_PASSWORDS=${REMOTE_PASSWORDS}" >> "$CI_ENV_FILE" # 缩进6个空格 + - echo "REMOTE_ONLINE_IDS=${REMOTE_ONLINE_IDS}" >> "$CI_ENV_FILE" # 缩进6个空格 + + # ========== 6. SCP推送产物(依赖编译+配置解析) ========== + scp-exe-to-servers: # 与fetch-deploy-config同级,缩进2个空格 + image: appleboy/drone-scp:1.6.2 # 子元素,缩进4个空格 + settings: # 子元素,缩进4个空格 + host: ${REMOTE_HOSTS} # settings内的项,缩进6个空格 + username: ${REMOTE_USERS} # 统一缩进6个空格 + password: ${REMOTE_PASSWORDS} # 统一缩进6个空格 + source: ./build/${BIN_NAME} # 统一缩进6个空格 + target: ${REMOTE_EXE_DIR}/ # 统一缩进6个空格 + strip_components: 1 # 统一缩进6个空格 + skip_verify: true # 统一缩进6个空格 + timeout: 30s # 统一缩进6个空格 + depends_on: # 子元素,缩进4个空格 + - build_logic # depends_on内的项,缩进6个空格 + - fetch-deploy-config # 统一缩进6个空格 \ No newline at end of file