feat(ci): onprem-release 分支构建后自动 SSH 部署到服务器

参考 gbase-frontend-onprem 的 CD 流程,在 docker-hub-build-push 中新增 deploy 参数与 when 块:构建&推送完成后通过 ssh-keyscan + add_ssh_keys 连接 onprem 服务器,sed 改写 docker-compose.yml 的 catalog-agent image 行并重启服务。仅 AMD64 任务在 onprem-release 分支启用,ARM64 与其他分支保持只构建。

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
shuirong 2026-04-27 18:42:04 +09:00
parent d1f61b9865
commit 4111c2c6ed

View File

@ -67,6 +67,9 @@ jobs:
type: string
docker-tag:
type: string
deploy:
type: boolean
default: false
steps:
- checkout
- run:
@ -92,11 +95,52 @@ jobs:
docker push <<parameters.repo>>:<<parameters.docker-tag>>
docker push <<parameters.repo>>:$IMAGE_TAG
# 把 IMAGE_TAG 透传到后续 stepCD SSH 部署需要使用)
echo "export IMAGE_TAG=$IMAGE_TAG" >> $BASH_ENV
bash scripts/ci/notify_feishu.sh \
--event docker_hub \
--image-repo <<parameters.repo>> \
--image-tag <<parameters.docker-tag>> \
--version-tag "$IMAGE_TAG"
- when:
# 仅当 deploy=true 且当前分支为 onprem-release 时才触发 CD避免其他分支误部署
condition:
and:
- << parameters.deploy >>
- equal: [ onprem-release, << pipeline.git.branch >> ]
steps:
# 将预先在 CircleCI 项目设置 → SSH Keys 上传的私钥加载到 ssh-agent
# ONPREM_DEPLOY_SSH_KEY_FINGERPRINT 是上传私钥后 CircleCI 返回的 MD5 指纹
- add_ssh_keys:
fingerprints:
- "$ONPREM_DEPLOY_SSH_KEY_FINGERPRINT"
- run:
name: SSH 部署到服务器(更新 catalog-agent 镜像并重启)
command: |
# 把服务器公钥写入 known_hosts避免首次连接时的交互确认
# 服务器 SSH 端口通过 ONPREM_DEPLOY_SSH_PORT 环境变量控制(例如 17290
mkdir -p ~/.ssh
ssh-keyscan -H -p "$ONPREM_DEPLOY_SSH_PORT" "$ONPREM_DEPLOY_SSH_HOST" >> ~/.ssh/known_hosts 2>/dev/null
# 将本次生成的 IMAGE_TAG 透传到远端脚本
# - 本地 shell 展开 $IMAGE_TAG 组装成远端命令前缀
# - heredoc 使用 'REMOTE' 单引号形式,避免本地对脚本体再次展开
# - sed 直接替换 catalog-agent 的整行 image 字段(兼容 "gptbasesparticle/..." 或
# "docker.gbase.ai/..." 等任意仓库前缀、以及 0.0.x 等任意标签格式)
# - 通过「标签首字符是数字」排除 arm64 等非 AMD64 镜像干扰(本 CD 仅在 AMD64 job 触发)
ssh -p "$ONPREM_DEPLOY_SSH_PORT" "$ONPREM_DEPLOY_SSH_USER@$ONPREM_DEPLOY_SSH_HOST" \
"IMAGE_TAG='$IMAGE_TAG' bash -s" \<<'REMOTE'
set -euo pipefail
cd gbase_onprem
echo "更新前 catalog-agent 镜像行:"
grep -E '^[[:space:]]*image:[[:space:]]*[^#[:space:]]*catalog-agent:[0-9]' docker-compose.yml || true
sed -i -E "s|^([[:space:]]*)image:[[:space:]]*[^#[:space:]]*catalog-agent:[0-9][^[:space:]]*|\1image: gptbasesparticle/catalog-agent:${IMAGE_TAG}|" docker-compose.yml
echo "更新后 catalog-agent 镜像行:"
grep -E "^[[:space:]]*image:[[:space:]]*gptbasesparticle/catalog-agent:${IMAGE_TAG}" docker-compose.yml
docker compose down catalog-agent
docker compose up catalog-agent -d
REMOTE
workflows:
backend_build_and_push:
@ -184,6 +228,8 @@ workflows:
repo: gptbasesparticle/catalog-agent
dockerfile: Dockerfile
docker-tag: latest
# 启用 CD构建&推送完成后 SSH 到服务器更新 catalog-agent 镜像(仅 onprem-release 分支生效,见 job 内 when 条件)
deploy: true
filters:
branches:
only: