All checks were successful
构建并部署到测试环境(无 SSH) / build-and-deploy (push) Successful in 4m0s
根本问题: - 第一次部署时复制的 docker-compose.prod.yml 没有环境变量 - 后续部署跳过复制,导致服务器一直使用旧版本配置 - 容器启动时因缺少 DB_HOST 环境变量立即退出 - 健康检查失败 → 容器 unhealthy 服务器日志证实: - 容器反复重启 - 每次都显示 '错误: DB_HOST 环境变量未设置' - entrypoint-api.sh 第10行检查失败后 exit 1 修复内容: - docker-compose.prod.yml 每次部署强制更新 - configs 目录保留现有配置(避免覆盖运行时调整) - 确保最新的环境变量配置生效
110 lines
3.9 KiB
YAML
110 lines
3.9 KiB
YAML
name: 构建并部署到测试环境(无 SSH)
|
||
|
||
on:
|
||
push:
|
||
branches:
|
||
- main
|
||
- dev
|
||
- test
|
||
|
||
env:
|
||
REGISTRY: registry.boss160.cn
|
||
API_IMAGE: registry.boss160.cn/junhong/cmp-fiber-api
|
||
WORKER_IMAGE: registry.boss160.cn/junhong/cmp-fiber-worker
|
||
DEPLOY_DIR: /opt/junhong_cmp
|
||
|
||
jobs:
|
||
build-and-deploy:
|
||
runs-on: ubuntu-latest
|
||
|
||
steps:
|
||
- name: 检出代码
|
||
run: |
|
||
# 添加 Nix 路径到 PATH(git 安装在这里)
|
||
export PATH="$HOME/.nix-profile/bin:/usr/local/bin:/usr/bin:/bin:$PATH"
|
||
# 跳过 SSL 验证(内网自签名证书)
|
||
export GIT_SSL_NO_VERIFY=1
|
||
git clone https://git.boss160.cn/csxj2026/junhong_cmp_fiber.git .
|
||
git checkout ${{ github.sha }}
|
||
|
||
- name: 设置镜像标签
|
||
id: tag
|
||
run: |
|
||
if [ "${{ github.ref }}" = "refs/heads/main" ]; then
|
||
echo "tag=latest" >> $GITHUB_OUTPUT
|
||
elif [ "${{ github.ref }}" = "refs/heads/dev" ]; then
|
||
echo "tag=dev" >> $GITHUB_OUTPUT
|
||
elif [ "${{ github.ref }}" = "refs/heads/test" ]; then
|
||
echo "tag=test" >> $GITHUB_OUTPUT
|
||
else
|
||
echo "tag=unknown" >> $GITHUB_OUTPUT
|
||
fi
|
||
|
||
- name: 登录 Docker Registry
|
||
run: |
|
||
echo "${{ secrets.REGISTRY_PASSWORD }}" | docker login "${{ env.REGISTRY }}" --username "${{ secrets.REGISTRY_USERNAME }}" --password-stdin
|
||
|
||
- name: 构建 API 镜像
|
||
run: |
|
||
docker build -f Dockerfile.api -t ${{ env.API_IMAGE }}:${{ steps.tag.outputs.tag }} .
|
||
docker tag ${{ env.API_IMAGE }}:${{ steps.tag.outputs.tag }} ${{ env.API_IMAGE }}:${{ github.sha }}
|
||
|
||
- name: 构建 Worker 镜像
|
||
run: |
|
||
docker build -f Dockerfile.worker -t ${{ env.WORKER_IMAGE }}:${{ steps.tag.outputs.tag }} .
|
||
docker tag ${{ env.WORKER_IMAGE }}:${{ steps.tag.outputs.tag }} ${{ env.WORKER_IMAGE }}:${{ github.sha }}
|
||
|
||
- name: 推送镜像到 Registry
|
||
run: |
|
||
docker push ${{ env.API_IMAGE }}:${{ steps.tag.outputs.tag }}
|
||
docker push ${{ env.API_IMAGE }}:${{ github.sha }}
|
||
docker push ${{ env.WORKER_IMAGE }}:${{ steps.tag.outputs.tag }}
|
||
docker push ${{ env.WORKER_IMAGE }}:${{ github.sha }}
|
||
|
||
- name: 部署到本地(仅 main 分支)
|
||
if: github.ref == 'refs/heads/main'
|
||
run: |
|
||
# 确保部署目录存在
|
||
mkdir -p ${{ env.DEPLOY_DIR }}/{configs,logs}
|
||
|
||
# 调试:显示当前目录和文件
|
||
echo "📍 当前工作目录: $(pwd)"
|
||
echo "📁 当前目录内容:"
|
||
ls -la
|
||
|
||
# 强制更新 docker-compose.prod.yml(确保使用最新配置)
|
||
echo "📋 更新部署配置文件..."
|
||
cp -v docker-compose.prod.yml ${{ env.DEPLOY_DIR }}/
|
||
|
||
# configs 目录只在不存在时初始化(避免覆盖运行时配置)
|
||
if [ ! -d ${{ env.DEPLOY_DIR }}/configs ] || [ -z "$(ls -A ${{ env.DEPLOY_DIR }}/configs 2>/dev/null)" ]; then
|
||
echo "📋 初始化配置目录..."
|
||
cp -rv configs/* ${{ env.DEPLOY_DIR }}/configs/
|
||
else
|
||
echo "✅ 配置目录已存在,保留现有配置"
|
||
fi
|
||
|
||
cd ${{ env.DEPLOY_DIR }}
|
||
|
||
echo "📥 拉取最新镜像..."
|
||
docker compose -f docker-compose.prod.yml pull
|
||
|
||
echo "🚀 重启服务..."
|
||
docker compose -f docker-compose.prod.yml up -d
|
||
|
||
echo "⏳ 等待服务启动..."
|
||
sleep 10
|
||
|
||
echo "✅ 部署完成!"
|
||
docker compose -f docker-compose.prod.yml ps
|
||
|
||
- name: 构建结果通知
|
||
if: always()
|
||
run: |
|
||
if [ "${{ job.status }}" = "success" ]; then
|
||
echo "✅ 构建成功: ${{ steps.tag.outputs.tag }}"
|
||
echo "📦 镜像标签: ${{ github.sha }}"
|
||
else
|
||
echo "❌ 构建失败"
|
||
fi
|