编辑文件 my-first-workflow.yaml

This commit is contained in:
xinian
2026-01-28 12:15:35 +08:00
committed by cnb
parent 4a5142d568
commit 1881b54692

View File

@@ -5,183 +5,75 @@ when:
- manual
branch: main
skip_clone: true # 关闭默认clone手动拉取代码
skip_clone: true
# 流水线核心步骤修复所有模板括号缺失问题
# 全局配置变量替换占位符即可使用
variables:
SCREEN_NAME: "logic_service"
REMOTE_EXE_DIR: "/opt/logic"
JSON_CONFIG_URL: "https://你的JSON配置地址.com/deploy.json"
LOG_PATH: "$HOME/run.log"
# 流水线核心步骤理顺依赖链确保各步骤依赖正确
steps:
# ========== 0. 变量验证提前检查关键变量 ==========
- name: validate env vars
image: alpine:latest
commands:
- |
# 检查核心部署变量是否配置
REQUIRED_VARS=("LOGIN_SERVER_HOST" "LOGIN_SERVER_USER" "LOGIN_SERVER_PASSWORD")
for var in "${REQUIRED_VARS[@]}"; do
if [ -z "${!var}" ]; then
echo "❌ 错误:未配置变量 $var请在Woodpecker项目设置中补充"
exit 1
fi
done
# 给可选变量设置默认值
export LOGIN_SERVER_PORT=${LOGIN_SERVER_PORT:-22}
# 打印变量调试用
echo "✅ 变量验证通过:"
echo "LOGIN_SERVER_HOST: ${LOGIN_SERVER_HOST}"
echo "LOGIN_SERVER_USER: ${LOGIN_SERVER_USER}"
echo "LOGIN_SERVER_PORT: ${LOGIN_SERVER_PORT}"
# 写入CI_ENV_FILE供后续步骤使用
echo "LOGIN_SERVER_HOST=${LOGIN_SERVER_HOST}" >> "${CI_ENV_FILE}"
echo "LOGIN_SERVER_USER=${LOGIN_SERVER_USER}" >> "${CI_ENV_FILE}"
echo "LOGIN_SERVER_PASSWORD=${LOGIN_SERVER_PASSWORD}" >> "${CI_ENV_FILE}"
echo "LOGIN_SERVER_PORT=${LOGIN_SERVER_PORT}" >> "${CI_ENV_FILE}"
# ========== 0. 同步代码到GitHub与prepare并行执行 ==========
sync-to-github:
image: tencentcom/git-sync
settings:
target_url: https://github.com/72wo/blazing.git
auth_type: https
username: ${GIT_USERNAME}
password: ${GIT_ACCESS_TOKEN}
when:
event:
- push
branch:
- main
# ========== 1. 替代clone拉取代码 ==========
- name: prepare
# ========== 1. 替代clone拉取代码核心依赖 ==========
prepare:
image: debian:bookworm
depends_on: [validate env vars]
environment:
WOODPECKER_SSH_KEY:
from_secret: WOODPECKER_SSH_KEY
commands:
- export GIT_CONFIG_URL="https://cnb:${CNB_ACCK}@cnb.cool/blzing/blazing"
# 调试验证变量是否传递
- echo "🔍 调试WOODPECKER_SSH_KEY变量长度 = ${#WOODPECKER_SSH_KEY}"
- echo "🔍 调试当前环境变量列表筛选SSH相关"
- env | grep -i ssh || echo "⚠️ 无SSH相关环境变量"
# 系统初始化
- apt update -y
- apt install -y --no-install-recommends ca-certificates curl git openssh-client openssl libssl-dev
- git clone --depth 1 --progress -v ${GIT_CONFIG_URL} blazing-project
- cd blazing-project
- echo "✅ 代码拉取完成,当前目录:$(pwd)"
# ========== 2. 生成版本号 ==========
- name: set version
image: golang:1.23
depends_on: [prepare]
commands:
- cd blazing-project
- VERSION="v$(git rev-parse --short=8 HEAD 2>/dev/null || echo "unknown")"
- mkdir -p .build-info
- echo "BUILD_VERSION=${VERSION}" >> .build-info/.env
- echo "构建版本号:${VERSION}"
# ========== 3. 缓存Go依赖 ==========
- name: cache go modules
image: meltwater/drone-cache:latest
depends_on: [prepare]
settings:
restore: true
mount:
- /go/pkg/mod
- /root/.cache/go-build
# 关键检查此处{{ }}完全闭合无缺失
cache_key: '{{ .Repo.Name }}-{{ .Commit.Branch }}-{{ checksum "blazing-project/go.mod" }}-{{ checksum "blazing-project/login/go.mod" }}'
# ========== 4. 编译Logic和Login服务 ==========
- name: build
image: golang:1.25
environment:
CGO_ENABLED: 0
GO111MODULE: on
GOSUMDB: off
depends_on:
- cache go modules
- set version
commands:
- cd blazing-project
- . .build-info/.env
- mkdir -p build
# 清理旧SSH文件严格配置权限
- rm -rf /root/.ssh/*
- mkdir -p /root/.ssh && chmod 700 /root/.ssh
- DEPLOY_KEY_FILE="$HOME/.ssh/deploy_key"
# 关键修复SSH密钥写入EOF内无缩进
- |
# 编译Logic服务
BIN_NAME="logic_${BUILD_VERSION}"
go mod download -x
go build -v -trimpath -buildvcs=false -ldflags "-s -w -buildid= -extldflags '-static'" -o ./build/${BIN_NAME} ./logic
chmod +x ./build/${BIN_NAME}
ls -lh ./build/${BIN_NAME}
# 编译Login服务
cd login
BIN_NAME="login_${BUILD_VERSION}"
go mod download -x
go build -v -trimpath -buildvcs=false -ldflags "-s -w -buildid= -extldflags '-static'" -o ./build/${BIN_NAME} .
chmod +x ./build/${BIN_NAME}
ls -lh ./build/${BIN_NAME}
mv ./build/${BIN_NAME} ../build/
cd ..
ls -lh ./build/
- echo "LOGIC_BIN=logic_${BUILD_VERSION}" >> "${CI_ENV_FILE}"
- echo "LOGIN_BIN=login_${BUILD_VERSION}" >> "${CI_ENV_FILE}"
cat > /root/.ssh/id_ed25519 << EOF
$WOODPECKER_SSH_KEY
EOF
chmod 600 /root/.ssh/id_ed25519
echo "✅ ED25519密钥写入完成"
# ========== 5. 重建缓存 ==========
- name: rebuild cache
image: meltwater/drone-cache:latest
depends_on: [build]
settings:
rebuild: true
mount:
- /go/pkg/mod
- /root/.cache/go-build
# 关键检查{{ }}完全闭合
cache_key: '{{ .Repo.Name }}-{{ .Commit.Branch }}-{{ checksum "blazing-project/go.mod" }}-{{ checksum "blazing-project/login/go.mod" }}'
# ========== 6. SCP推送产物检查所有{{ }}闭合 ==========
- name: deploy to login server
image: appleboy/drone-scp:1.6.2
imports: https://cnb.cool/blzing/key/-/blob/main/githubkey.yml
depends_on: [rebuild cache]
settings:
host: {{ .LOGIN_SERVER_HOST }}
username: {{ .LOGIN_SERVER_USER }}
password: {{ .LOGIN_SERVER_PASSWORD }}
port: {{ .LOGIN_SERVER_PORT }}
source:
- ./blazing-project/build/login_*
- ./blazing-project/build/logic_*
target: /opt/login/
strip_components: 2
skip_verify: true
timeout: 30s
# ========== 7. SSH启动服务检查所有{{ }}闭合 ==========
- name: start login and move logic
image: appleboy/drone-ssh:1.6.2
imports: https://cnb.cool/blzing/key/-/blob/main/githubkey.yml
depends_on: [deploy to login server]
settings:
host: {{ .LOGIN_SERVER_HOST }}
username: {{ .LOGIN_SERVER_USER }}
password: {{ .LOGIN_SERVER_PASSWORD }}
port: {{ .LOGIN_SERVER_PORT }}
script:
- |
cd /opt/login
BIN_NAME=$(ls -t login_v* 2>/dev/null | head -1)
echo "BIN_NAME: $BIN_NAME"
if [ -z "$BIN_NAME" ]; then
echo "❌ 未找到可执行的login文件"
exit 1
fi
echo "📦 启动Login服务 | Binary: $BIN_NAME"
# 停止旧的screen会话
session_name="login"
session=$(screen -ls 2>/dev/null | grep -o "[0-9]*\.${session_name}" || true)
if [[ ! -z "$session" ]]; then
screen -X -S "$session_name" stuff "^C"
expect -c "exec screen -x ${session_name}; wait; exit" 2>/dev/null || true
screen -X -S "$session_name" quit 2>/dev/null || true
echo "Info: Stopped login app."
fi
sleep 1
# 启动新进程
screen -dmS ${session_name} ./${BIN_NAME}
echo "✅ Login服务启动成功 | Screen: ${session_name}"
# 健康检查
sleep 3
if screen -list 2>/dev/null | grep -q "${session_name}"; then
echo "✅ 服务健康检查通过 | Screen: ${session_name}"
else
echo "❌ 服务健康检查失败 | Screen: ${session_name} 不存在"
exit 1
fi
# 移动logic产物
LOGIC_BIN=$(ls -t logic_v* 2>/dev/null | head -1)
if [ -n "$LOGIC_BIN" ]; then
mkdir -p /opt/login/public
mv $LOGIC_BIN /opt/login/public/
echo "✅ Logic产物已移动到 /opt/login/public/ | 文件: $(basename $LOGIC_BIN)"
else
echo "⚠ 未找到Logic产物"
fi
# 添加GitHub主机密钥
- SSH_KNOWN_HOSTS_FILE="$HOME/.ssh/known_hosts"
- ssh-keyscan -H github.com > /root/.ssh/known_hosts
- chmod 600 /root/.ssh/known_hosts
- echo "🔍 ${#CI_REPO_CLONE_SSH_URL}调试: ${CI_REPO_CLONE_SSH_URL}"
- git config --global core.compression 0
- export GIT_CONFIG_URL="https://cnb:${CNB_ACCK}@cnb.cool/blzing/blazing"
- git clone --depth 1 --progress -v ${GIT_CONFIG_URL}
# 拉取代码
- echo "✅ 代码拉取完成"