diff --git a/.woodpecker/my-first-workflow.yaml b/.woodpecker/my-first-workflow.yaml index 3c2107390..6fa05212f 100644 --- a/.woodpecker/my-first-workflow.yaml +++ b/.woodpecker/my-first-workflow.yaml @@ -5,94 +5,99 @@ when: - manual branch: main -skip_clone: true +skip_clone: true # 关闭默认clone,手动拉取代码 - - - -# 流水线核心步骤:理顺依赖链,确保各步骤依赖正确 +# 流水线核心步骤:修复层级缩进+依赖链+变量传递 steps: -- name: prepare - image: debian:bookworm - environment: # ========== 1. 替代clone:拉取代码(核心依赖) ========== - - commands: - - export GIT_CONFIG_URL="https://cnb:"+$CNB_ACCK"@cnb.cool/blzing/blazing" + - name: prepare + image: debian:bookworm + commands: + # 修复:Shell变量拼接错误(移除多余"+"和引号,用${}规范引用) + - export GIT_CONFIG_URL="https://cnb:${CNB_ACCK}@cnb.cool/blzing/blazing" # 系统初始化 - - apt update -y - # 系统初始化 - - apt install -y --no-install-recommends ca-certificates curl git openssh-client openssl libssl-dev + - apt update -y + - apt install -y --no-install-recommends ca-certificates curl git openssh-client openssl libssl-dev + # 调试变量(可选,上线后可删除) + - echo "🔍 调试:GIT_CONFIG_URL长度=${#GIT_CONFIG_URL},值=${GIT_CONFIG_URL}" + # 拉取代码(--depth 1 浅克隆提速) + - git clone --depth 1 --progress -v ${GIT_CONFIG_URL} blazing-project + # 修复:必须进入项目目录,否则后续go build找不到代码 + - cd blazing-project + - echo "✅ 代码拉取完成,当前目录:$(pwd)" -# 格式:git clone https://用户名:密码@仓库地址 - - echo "🔍 ${#GIT_CONFIG_URL}调试: ${GIT_CONFIG_URL}" + # ========== 2. 初始化Go环境(依赖prepare:代码拉取完成) ========== + - name: prepare-go + image: golang:1.25 + depends_on: [prepare] + commands: + - cd blazing-project # 同步进入项目目录 + - go version + # 增强容错:失败时输出详细信息 + - go mod download -x || { echo "❌ 下载Go依赖失败"; ls -lh go.mod; exit 1; } + - go mod verify || { echo "❌ 验证Go依赖失败"; exit 1; } + - echo "✅ Go环境初始化完成" - - git clone --depth 1 --progress -v ${GIT_CONFIG_URL} - # 拉取代码 - - - echo "✅ 代码拉取完成" + # ========== 3. 生成版本号(依赖prepare-go:Go环境就绪) ========== + - name: set-version + image: golang:1.25 + depends_on: [prepare-go] + commands: + - cd blazing-project + - | + if [ -n "${CI_COMMIT_TAG}" ]; then + VERSION="${CI_COMMIT_TAG}" + else + VERSION="v$(git rev-parse --short=8 HEAD 2>/dev/null || echo "unknown")" + fi + # 确保CI_ENV_FILE目录存在(Woodpecker预定义变量,用于跨步骤传参) + mkdir -p "$(dirname "${CI_ENV_FILE}")" + echo "BUILD_VERSION=${VERSION}" >> "${CI_ENV_FILE}" + echo "✅ 生成版本号:${VERSION}" - # # ========== 2. 初始化Go环境(依赖prepare:代码拉取完成) ========== - # prepare-go: # 与prepare同级,缩进2个空格 - # image: golang:1.25 # 子元素,缩进4个空格 - # depends_on: [prepare] # 子元素,缩进4个空格 - # commands: # 子元素,缩进4个空格 - # - go version # commands内的项,缩进6个空格 - # - go mod download -x || { echo "❌ 下载Go依赖失败"; exit 1; } # 统一缩进6个空格 - # - go mod verify || { echo "❌ 验证Go依赖失败"; exit 1; } # 统一缩进6个空格 - # - echo "✅ Go环境初始化完成" # 统一缩进6个空格 - - # # ========== 3. 生成版本号(依赖prepare-go:Go环境就绪) ========== - # set-version: # 与prepare-go同级,缩进2个空格 - # image: golang:1.25 # 子元素,缩进4个空格 - # depends_on: [prepare-go] # 子元素,缩进4个空格 - # commands: # 子元素,缩进4个空格 - # - | # commands内的项,缩进6个空格 - # if [ -n "${CI_COMMIT_TAG}" ]; then - # VERSION="${CI_COMMIT_TAG}" - # else - # VERSION="v$(git rev-parse --short=8 HEAD 2>/dev/null || echo "unknown")" - # fi - # mkdir -p "$(dirname "$CI_ENV_FILE")" - # echo "BUILD_VERSION=${VERSION}" >> "$CI_ENV_FILE" - # echo "✅ 生成版本号:${VERSION}" - - # ========== 4. 编译Go服务(核心依赖:prepare+prepare-go+set-version) ========== - build_logic: # 与set-version同级,缩进2个空格 - image: golang:1.25 # 子元素,缩进4个空格 - depends_on: [prepare] # 子元素,缩进4个空格 - environment: # 子元素,缩进4个空格 - CGO_ENABLED: 0 # environment内的项,缩进6个空格 - GO111MODULE: on # 统一缩进6个空格 - GOSUMDB: off # 统一缩进6个空格 - commands: # 子元素,缩进4个空格 - - mkdir -p build # commands内的项,缩进6个空格 - - BIN_NAME="logic_${CI_STEP_STARTED}" # 缩进6个空格 - - | # 缩进6个空格 + # ========== 4. 编译Go服务(依赖:prepare+prepare-go+set-version) ========== + - name: build_logic + image: golang:1.25 + depends_on: [prepare, prepare-go, set-version] + environment: + CGO_ENABLED: 0 + GO111MODULE: on + GOSUMDB: off + commands: + - cd blazing-project + - mkdir -p build + # 定义二进制文件名(加入版本号更易追溯) + - BIN_NAME="logic_${BUILD_VERSION}_${CI_STEP_STARTED}" + - | go build -v \ -p=4 \ -trimpath \ -buildvcs=false \ - -ldflags "-s -w -buildid= -extldflags '-static' -X main.version=${CI_STEP_STARTED}" \ + -ldflags "-s -w -buildid= -extldflags '-static' -X main.version=${BUILD_VERSION}" \ -o ./build/${BIN_NAME} \ ./logic - - | # 缩进6个空格 + # 校验编译产物 + - | if [ ! -f ./build/${BIN_NAME} ]; then echo "❌ 编译失败:产物${BIN_NAME}不存在" + ls -lh ./build/ exit 1 fi - - ls -lh ./build/ # 缩进6个空格 - - ./build/${BIN_NAME} -v || true # 缩进6个空格 - - echo "✅ Go服务编译完成" # 缩进6个空格 + - ls -lh ./build/ + - ./build/${BIN_NAME} -v || true + # 修复:将BIN_NAME写入CI_ENV_FILE,供后续scp步骤使用 + - echo "BIN_NAME=${BIN_NAME}" >> "${CI_ENV_FILE}" + - echo "✅ Go服务编译完成,产物:${BIN_NAME}" # ========== 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个空格 + - name: fetch-deploy-config + image: alpine:latest + depends_on: [prepare] + commands: + - apk add --no-cache curl jq + - echo "🔧 拉取部署配置:${JSON_CONFIG_URL}" + # 增强重试逻辑(3次重试) + - | 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}次拉取失败,重试中..." @@ -102,7 +107,8 @@ steps: echo "❌ 拉取JSON配置失败" exit 1 fi - - | # 缩进6个空格 + # 解析JSON配置(兼容数组/对象格式) + - | 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/,$//') @@ -119,30 +125,32 @@ steps: 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个空格 + - echo "✅ 配置解析完成 | 服务器:${REMOTE_HOSTS} | OnlineID:${REMOTE_ONLINE_IDS}" + # 写入环境文件供后续步骤使用 + - echo "REMOTE_HOSTS=${REMOTE_HOSTS}" >> "${CI_ENV_FILE}" + - echo "REMOTE_USERS=${REMOTE_USERS}" >> "${CI_ENV_FILE}" + - echo "REMOTE_PASSWORDS=${REMOTE_PASSWORDS}" >> "${CI_ENV_FILE}" + - echo "REMOTE_ONLINE_IDS=${REMOTE_ONLINE_IDS}" >> "${CI_ENV_FILE}" # ========== 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个空格 + - name: scp-exe-to-servers + image: appleboy/drone-scp:1.6.2 + depends_on: + - build_logic + - fetch-deploy-config + settings: + host: ${REMOTE_HOSTS} + username: ${REMOTE_USERS} + password: ${REMOTE_PASSWORDS} + source: ./blazing-project/build/${BIN_NAME} # 修复:补充项目目录路径 + target: ${REMOTE_EXE_DIR}/ + strip_components: 3 # 修复:路径层级调整(blazing-project/build/xxx → 直接取xxx) + skip_verify: true + timeout: 30s