2026-06-22 14:58:27 +08:00

88 lines
3.0 KiB
YAML

name: main
on:
push:
branches: ["main"]
jobs:
build-and-push:
name: Build and push to Aliyun ACR
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: https://gitee.com/zsqai/checkout@v4
- name: Set up Docker Buildx
uses: https://gitee.com/zsqai/setup-buildx-action@v3
- name: Login to Aliyun Container Registry
uses: https://gitee.com/zsqai/login-action@v3
with:
registry: ${{ vars.ALIYUN_REGISTRY }}
username: ${{ vars.ALIYUN_USERNAME }}
password: ${{ secrets.ALIYUN_PASSWORD }}
- name: Build and push Docker image
uses: https://gitee.com/zsqai/build-push-action@v5
with:
context: .
push: true
# 禁用所有缓存,确保每次都是全新构建
no-cache: true
build-args: |
BUILD_VERSION=${{ github.sha }}
BUILD_TIME=${{ github.run_number }}
CACHE_BUST=${{ github.run_id }}
tags: |
${{ vars.ALIYUN_REGISTRY }}/${{ vars.ALIYUN_NAMESPACE }}/${{ vars.ALIYUN_REPO }}:latest
${{ vars.ALIYUN_REGISTRY }}/${{ vars.ALIYUN_NAMESPACE }}/${{ vars.ALIYUN_REPO }}:${{ github.sha }}
deploy:
name: Deploy to server
runs-on: ubuntu-latest
needs: build-and-push
steps:
- name: Deploy via SSH
uses: https://gitee.com/zsqai/ssh-action@v1.0.3
with:
host: ${{ vars.HOST }}
username: root
password: ${{ secrets.MAIN_HOST_PASSWORD }}
port: 22
script: |
# 登录阿里云镜像仓库
docker login --username=${{ vars.ALIYUN_USERNAME }} --password=${{ secrets.ALIYUN_PASSWORD }} ${{ vars.ALIYUN_REGISTRY }}
# 停止并删除旧容器
docker stop website-01 2>/dev/null || true
docker rm website-01 2>/dev/null || true
# 删除旧镜像(强制重新拉取)
docker rmi ${{ vars.ALIYUN_REGISTRY }}/${{ vars.ALIYUN_NAMESPACE }}/${{ vars.ALIYUN_REPO }}:latest 2>/dev/null || true
# 强制拉取最新镜像
docker pull ${{ vars.ALIYUN_REGISTRY }}/${{ vars.ALIYUN_NAMESPACE }}/${{ vars.ALIYUN_REPO }}:latest
# 运行新容器
docker run -d \
--name website-01 \
--restart always \
-p 8085:3002 \
-e NODE_OPTIONS="--max-old-space-size=4096" \
-e NODE_ENV="production" \
${{ vars.ALIYUN_REGISTRY }}/${{ vars.ALIYUN_NAMESPACE }}/${{ vars.ALIYUN_REPO }}:latest
# 等待启动
sleep 3
# 查看 BUILD_ID 确认更新
echo "=== Build ID ==="
docker exec -it website-01 cat .next/BUILD_ID 2>/dev/null || echo "Cannot read BUILD_ID"
# 查看日志
echo ""
echo "=== Container Logs ==="
docker logs website-01 --tail 20
# 清理无用镜像
docker image prune -f