voxblog/.gitea/workflows/deploy.yml
adminuser 2df902979a
Some checks failed
Deploy to Production / deploy (push) Failing after 2m38s
Align deployment workflow with production compose stack
2025-10-26 21:12:01 +00:00

85 lines
2.3 KiB
YAML

name: Deploy to Production
on:
push:
branches:
- main
jobs:
deploy:
runs-on: ubuntu-latest
env:
COMPOSE_PROJECT_NAME: voxblog
steps:
- name: Checkout code
uses: actions/checkout@v3
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v2
- name: Create .env file
run: |
cat > .env << EOF
MYSQL_ROOT_PASSWORD=${{ secrets.MYSQL_ROOT_PASSWORD }}
MYSQL_PASSWORD=${{ secrets.MYSQL_PASSWORD }}
ADMIN_PASSWORD=${{ secrets.ADMIN_PASSWORD }}
OPENAI_API_KEY=${{ secrets.OPENAI_API_KEY }}
GHOST_ADMIN_API_KEY=${{ secrets.GHOST_ADMIN_API_KEY }}
GHOST_ADMIN_API_URL=${{ secrets.GHOST_ADMIN_API_URL }}
S3_BUCKET=${{ secrets.S3_BUCKET }}
S3_REGION=${{ secrets.S3_REGION }}
S3_ACCESS_KEY=${{ secrets.S3_ACCESS_KEY }}
S3_SECRET_KEY=${{ secrets.S3_SECRET_KEY }}
S3_ENDPOINT=${{ secrets.S3_ENDPOINT }}
VITE_API_URL=${{ secrets.VITE_API_URL }}
EOF
- name: Stop existing containers
run: docker-compose down || true
- name: Build images
run: docker-compose build --no-cache
- name: Start containers
run: docker-compose up -d
- name: Wait for services
run: sleep 15
- name: Run database migrations
run: docker-compose exec -T api pnpm run drizzle:migrate || echo "Migration skipped"
- name: Health check API
run: |
for i in {1..10}; do
if curl -f http://localhost:3301/api/health; then
echo "API is healthy"
exit 0
fi
echo "Waiting for API... ($i/10)"
sleep 5
done
echo "API health check failed"
docker-compose logs api
exit 1
- name: Health check Admin
run: |
if curl -f http://localhost:3300; then
echo "Admin is healthy"
else
echo "Admin health check failed"
docker-compose logs admin
exit 1
fi
- name: Clean up old images
run: docker image prune -af --filter "until=24h"
- name: Deployment summary
run: |
echo "✅ Deployment successful!"
echo "Services:"
docker-compose ps