feat: add CI/CD workflows
Deploy to Dev / deploy-dev (push) Failing after 51s Details

This commit is contained in:
Dev Server 2026-02-12 22:33:08 +03:00
parent bd1541d622
commit adf395e521
2 changed files with 150 additions and 0 deletions

View File

@ -0,0 +1,60 @@
name: Deploy to Dev
on:
push:
branches: [ main, master, develop, dev ]
paths-ignore:
- '**.md'
- '.gitignore'
- '.cursor/**'
jobs:
deploy-dev:
runs-on: ubuntu-latest
if: github.event_name == 'push'
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Setup SSH
uses: webfactory/ssh-agent@v0.9.0
with:
ssh-private-key: ${{ secrets.SSH_PRIVATE_KEY }}
- name: Deploy to Dev Server
uses: appleboy/ssh-action@v1.0.0
with:
host: ${{ secrets.DEV_HOST }}
username: ${{ secrets.DEV_USER }}
key: ${{ secrets.SSH_PRIVATE_KEY }}
script: |
set -e
cd /var/www/platform/dev
echo "📦 Pulling latest changes from repository..."
git pull origin main || git pull origin master || git pull origin develop || git pull origin dev || true
echo "🔄 Restarting Docker services..."
docker compose restart
echo "📊 Running migrations (if needed)..."
docker compose exec -T web python manage.py migrate || true
echo "📁 Collecting static files (if needed)..."
docker compose exec -T web python manage.py collectstatic --noinput || true
echo "✅ Dev deployment completed successfully"
echo " You can continue working directly on the server"
- name: Health Check
uses: appleboy/ssh-action@v1.0.0
with:
host: ${{ secrets.DEV_HOST }}
username: ${{ secrets.DEV_USER }}
key: ${{ secrets.SSH_PRIVATE_KEY }}
script: |
sleep 10
docker compose ps
curl -f http://localhost:8124/health/ || exit 1
echo "✅ Health check passed"

View File

@ -0,0 +1,90 @@
name: Deploy to Production
on:
push:
branches: [ main, master ]
tags: [ 'v*' ]
paths-ignore:
- '**.md'
- '.gitignore'
- '.cursor/**'
jobs:
deploy-production:
runs-on: ubuntu-latest
if: github.event_name == 'push'
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Setup SSH
uses: webfactory/ssh-agent@v0.9.0
with:
ssh-private-key: ${{ secrets.SSH_PRIVATE_KEY }}
- name: Deploy to Production Server
uses: appleboy/ssh-action@v1.0.0
with:
host: ${{ secrets.PROD_HOST }}
username: ${{ secrets.PROD_USER }}
key: ${{ secrets.SSH_PRIVATE_KEY }}
script: |
set -e
cd /var/www/platform/prod
# Load environment configuration
if [ -f .end.prod ]; then
source .end.prod
fi
# Pull latest changes
git pull origin main || git pull origin master || true
# Backup database before deployment
if [ "$BACKUP_BEFORE_DEPLOY" = "true" ]; then
mkdir -p /var/www/platform/backups
docker compose exec -T db pg_dump -U ${POSTGRES_USER} ${POSTGRES_DB} > /var/www/platform/backups/backup_$(date +%Y%m%d_%H%M%S).sql || true
fi
# Stop services gracefully
docker compose down --timeout 30 || true
# Build and start services
docker compose build --no-cache
docker compose up -d
# Wait for services to be ready
sleep 15
# Run migrations
docker compose exec -T web python manage.py migrate || true
# Collect static files
docker compose exec -T web python manage.py collectstatic --noinput || true
# Clear cache
docker compose exec -T web python manage.py clearcache || true
# Restart services
docker compose restart
echo "✅ Production deployment completed successfully"
- name: Health Check
uses: appleboy/ssh-action@v1.0.0
with:
host: ${{ secrets.PROD_HOST }}
username: ${{ secrets.PROD_USER }}
key: ${{ secrets.SSH_PRIVATE_KEY }}
script: |
sleep 15
docker compose ps
curl -f http://localhost:8123/health/ || exit 1
echo "✅ Health check passed"
- name: Notify Deployment
if: always()
run: |
echo "Deployment status: ${{ job.status }}"
# Здесь можно добавить уведомления (Telegram, Slack, Email и т.д.)