name: Backend Deploy (Go + Docker) on: push: branches: - main paths: - 'server/**' - '.gitea/workflows/backend-deploy.yml' jobs: deploy: runs-on: arm container: image: catthehacker/ubuntu:act-latest steps: - name: 获取代码 uses: actions/checkout@v4 - name: 安装 Go uses: actions/setup-go@v5 with: go-version: '1.22' - name: 编译后端可执行文件 run: | cd server env GOOS=linux GOARCH=arm64 go build -o server_bin ./cmd/server - name: 准备部署文件 run: | mkdir -p deploy cp server/server_bin deploy/ cp server/Dockerfile deploy/ cp server/docker-compose.yml deploy/ cp server/.env.example deploy/ - name: 部署文件到服务器 uses: up9cloud/action-rsync@master env: USER: root HOST: 144.24.60.0 KEY: ${{secrets.USAARMLOGIN_SSH_KEY}} ARGS: -avz --delete --exclude '.env' SSH_ARGS: "-p 22 -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no -o ServerAliveInterval=60 -o ServerAliveCountMax=3" SOURCE: ./deploy/ TARGET: /var/admin/InsightReply/server/ VERBOSE: true - name: 重启服务 (Docker Compose) uses: appleboy/ssh-action@v1.0.3 with: host: 144.24.60.0 username: root key: ${{secrets.USAARMLOGIN_SSH_KEY}} script: | cd /var/admin/InsightReply/server # 首次部署时,从模板创建 .env if [ ! -f .env ]; then echo "⚠️ .env not found, creating from .env.example" cp .env.example .env echo "📝 请在服务器上编辑 /var/admin/InsightReply/server/.env 填入真实密钥" fi sync sleep 3 # 检查是否有正在移除的容器,等待其完成 for i in $(seq 1 10); do if docker ps -a 2>/dev/null | grep -q 'Removal'; then echo "Waiting for container removal... ($i/10)" sleep 3 else break fi done # 使用 --remove-orphans 更彻底地清理,并直接 build up docker compose up -d --build --remove-orphans