89 lines
3.0 KiB
YAML
89 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 network inspect web-network >/dev/null 2>&1 || docker network create web-network
|
|
|
|
# 停止并删除旧容器
|
|
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 \
|
|
--network web-network \
|
|
-e NODE_OPTIONS="--max-old-space-size=4096" \
|
|
-e NODE_ENV="production" \
|
|
${{ vars.ALIYUN_REGISTRY }}/${{ vars.ALIYUN_NAMESPACE }}/${{ vars.ALIYUN_REPO }}:latest
|
|
|
|
# 将 NPM 容器也连接到同一网络(如果还没连接)
|
|
docker network connect web-network nginx-proxy-manager 2>/dev/null || true
|
|
|
|
# 等待启动
|
|
sleep 3
|
|
|
|
# 查看日志
|
|
echo ""
|
|
echo "=== Container Logs ==="
|
|
docker logs website-01 --tail 20
|
|
|
|
# 清理无用镜像
|
|
docker image prune -f |