Update my-first-workflow.yaml

This commit is contained in:
2026-01-26 14:06:51 +08:00
committed by GitHub
parent 766691276e
commit 4dc6376fc1

View File

@@ -1,7 +1,9 @@
# 触发条件push到main分支手动触发
when:
- event: [push, pull_request, manual]
event: [push, manual]
branch: main
branch: main
# 克隆配置启用SSH拉取代码
clone:
git:
image: woodpeckerci/plugin-git
@@ -9,20 +11,193 @@ clone:
depth: 50
lfs: false
use-ssh: true
steps:
- name: build
image: debian
commands:
- echo "This is the build step"
- echo "binary-data-123" > executable
- name: a-test-step
# 全局环境变量
environment:
CGO_ENABLED: 0
GO111MODULE: on
GOSUMDB: off
SCREEN_NAME: logic_service # screen会话名称全局统一
REMOTE_EXE_DIR: /opt/logic # 远程服务器程序存放目录
JSON_CONFIG_URL: "https://xxx.com/deploy-config.json" # 替换为你的JSON配置地址
# JSON字段名与你的JSON对应无需修改
JSON_FIELD_ADDR: "loginaddr"
JSON_FIELD_USER: "user"
JSON_FIELD_PASS: "password"
JSON_FIELD_ONLINEID: "online_id" # 新增解析JSON中的online_id字段
# 流水线核心步骤
pipeline:
# 1. 缓存Go依赖
cache-go-mod:
image: woodpeckerci/plugin-cache
settings:
mount:
- ~/go/pkg/mod
- ~/.cache/go-build
key: ${CI_OS}-go-${CI_COMMIT_SHA:0:8}
restore_keys:
- ${CI_OS}-go-
# 2. 配置Go环境并预下载依赖
prepare-go:
image: golang:1.25
commands:
go build -v \
-p=4 \
-trimpath \
-buildvcs=false \
-ldflags "-s -w -buildid= -extldflags '-static'" \
-o ./build/${CI_COMMIT_SHA} \
./logic
- go version
- go mod download -x
# 3. 生成构建版本号
set-version:
image: golang:1.25
commands:
- VERSION="v$(git rev-parse --short=8 HEAD)"
- echo "BUILD_VERSION=${VERSION}" >> $CI_ENV_FILE
- echo "构建版本号:${VERSION}"
# 4. 编译Go服务
build-logic:
image: golang:1.25
commands:
- mkdir -p build
- BIN_NAME="logic_${BUILD_VERSION}"
- echo "BIN_NAME=${BIN_NAME}" >> $CI_ENV_FILE
- 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}"
# 5. 获取并解析JSON配置核心修改新增解析online_id
fetch-deploy-config:
image: alpine:latest
commands:
- apk add --no-cache curl jq
- echo "从${JSON_CONFIG_URL}拉取部署配置..."
- curl -sSL ${JSON_CONFIG_URL} -o /tmp/deploy-config.json
- if [ ! -f /tmp/deploy-config.json ]; then
echo "❌ 拉取JSON配置失败"
exit 1
fi
# 检测JSON格式数组/对象新增解析online_id
- |
JSON_TYPE=$(jq -r 'type' /tmp/deploy-config.json)
if [ "$JSON_TYPE" = "array" ]; then
# 多服务器提取所有地址用户名密码online_id逗号分隔一一对应
REMOTE_HOSTS=$(jq -r ".[].${JSON_FIELD_ADDR}" /tmp/deploy-config.json | tr '\n' ',' | sed 's/,$//')
REMOTE_USERS=$(jq -r ".[].${JSON_FIELD_USER}" /tmp/deploy-config.json | tr '\n' ',' | sed 's/,$//')
REMOTE_PASSWORDS=$(jq -r ".[].${JSON_FIELD_PASS}" /tmp/deploy-config.json | tr '\n' ',' | sed 's/,$//')
REMOTE_ONLINE_IDS=$(jq -r ".[].${JSON_FIELD_ONLINEID}" /tmp/deploy-config.json | tr '\n' ',' | sed 's/,$//')
else
# 单服务器直接提取所有字段
REMOTE_HOSTS=$(jq -r ".${JSON_FIELD_ADDR}" /tmp/deploy-config.json)
REMOTE_USERS=$(jq -r ".${JSON_FIELD_USER}" /tmp/deploy-config.json)
REMOTE_PASSWORDS=$(jq -r ".${JSON_FIELD_PASS}" /tmp/deploy-config.json)
REMOTE_ONLINE_IDS=$(jq -r ".${JSON_FIELD_ONLINEID}" /tmp/deploy-config.json)
fi
# 输出解析结果调试用
- echo "解析出的服务器地址:${REMOTE_HOSTS}"
- echo "解析出的用户名:${REMOTE_USERS}"
- echo "解析出的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:
image: appleboy/drone-scp
settings:
host: ${REMOTE_HOSTS}
username: ${REMOTE_USERS}
password: ${REMOTE_PASSWORDS}
source: ./build/${BIN_NAME}
target: ${REMOTE_EXE_DIR}/
strip_components: 1
skip_verify: true
environment:
- BIN_NAME=${BIN_NAME}
- REMOTE_EXE_DIR=${REMOTE_EXE_DIR}
depends_on: [build-logic, fetch-deploy-config]
# 7. 远程部署核心修改使用动态online_id启动程序
deploy-to-servers:
image: appleboy/drone-ssh
settings:
host: ${REMOTE_HOSTS}
username: ${REMOTE_USERS}
password: ${REMOTE_PASSWORDS}
skip_verify: true
# 脚本新增读取当前服务器的online_id动态拼接启动参数
script:
# 第一步检查并安装screen无修改
- |
echo "检查Screen是否已安装..."
if command -v screen &> /dev/null; then
echo "=== Screen已安装跳过 ==="
else
echo "=== Screen未安装开始安装 ==="
if command -v apt &> /dev/null; then
apt update -y && apt install -y screen
elif command -v yum &> /dev/null; then
yum install -y screen
elif command -v dnf &> /dev/null; then
dnf install -y screen
elif command -v pacman &> /dev/null; then
pacman -S --noconfirm screen
else
echo "❌ 不支持的包管理器无法安装Screen"
exit 1
fi
command -v screen || { echo "❌ Screen安装失败"; exit 1; }
fi
# 第二步设置程序执行权限无修改
- mkdir -p ${REMOTE_EXE_DIR}
- chmod +x ${REMOTE_EXE_DIR}/${BIN_NAME} || { echo "❌ 设置权限失败"; exit 1; }
# 第三步停止旧会话无修改
- screen -S ${SCREEN_NAME} -X quit || true
# 第四步启动新程序核心修改使用JSON解析的online_id
- |
echo "启动Screen会话[${SCREEN_NAME}]OnlineID${REMOTE_ONLINE_IDS}"
screen -dmS ${SCREEN_NAME} bash -c "\"${REMOTE_EXE_DIR}/${BIN_NAME}\" -id=${REMOTE_ONLINE_IDS} | tee -a \"\$HOME/run.log\""
sleep 2
if screen -ls | grep -q "${SCREEN_NAME}"; then
echo "✅ 程序启动成功!会话:${SCREEN_NAME} | OnlineID${REMOTE_ONLINE_IDS}"
screen -ls
else
echo "❌ 程序启动失败,未创建[${SCREEN_NAME}]会话"
screen -ls
exit 1
fi
environment:
- BIN_NAME=${BIN_NAME}
- SCREEN_NAME=${SCREEN_NAME}
- REMOTE_EXE_DIR=${REMOTE_EXE_DIR}
- REMOTE_ONLINE_IDS=${REMOTE_ONLINE_IDS} # 传递解析的online_id
depends_on: scp-exe-to-servers
# 8. 打印部署完成信息新增显示online_id
print-deploy-info:
image: alpine:latest
commands:
- echo "======================================"
- echo "✅ 部署完成!"
- echo "版本号:${BUILD_VERSION}"
- echo "触发方式:${CI_EVENT_NAME}"
- echo "程序名称:${BIN_NAME}"
- echo "远程部署目录:${REMOTE_EXE_DIR}"
- echo "Screen会话名${SCREEN_NAME}"
- echo "部署服务器:${REMOTE_HOSTS}"
- echo "服务器OnlineID${REMOTE_ONLINE_IDS}" # 新增显示online_id
- echo "对应Commit${CI_COMMIT_SHA}"
- echo "======================================"
depends_on: deploy-to-servers