Files
AutonetSellCar/deploy/deploy-staging.sh
AutonetSellCar Deploy 1f0dcb1ddb Initial commit: AutonetSellCar platform with deployment system
- Frontend: Next.js 14 with TypeScript
- Backend: FastAPI with SQLAlchemy
- Agent: Carmodoo sync agent
- Deployment: Docker Compose based staging/production setup
- Scripts: Automated deployment with rollback support

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2025-12-30 13:24:39 +09:00

71 lines
1.8 KiB
Bash

#!/bin/bash
# AutonetSellCar Staging Deployment Script
# This script is executed automatically by git post-receive hook
set -e
STAGING_DIR="/opt/autonet/staging"
LOG_FILE="/opt/autonet/logs/staging-deploy.log"
log() {
echo "[$(date '+%Y-%m-%d %H:%M:%S')] $1" | tee -a "$LOG_FILE"
}
mkdir -p /opt/autonet/logs
log "=========================================="
log "Starting Staging Deployment"
log "=========================================="
cd $STAGING_DIR
log "[1/4] Stopping existing containers..."
docker compose -f docker-compose.staging.yml down 2>/dev/null || true
log "[2/4] Building containers (this may take a while)..."
docker compose -f docker-compose.staging.yml build --no-cache
log "[3/4] Starting containers..."
docker compose -f docker-compose.staging.yml up -d
log "[4/4] Waiting for services to be ready..."
sleep 15
# Health check
BACKEND_OK=false
FRONTEND_OK=false
for i in {1..5}; do
if curl -sf http://localhost:8001/docs > /dev/null 2>&1; then
BACKEND_OK=true
break
fi
log "Backend not ready yet, retry $i/5..."
sleep 5
done
for i in {1..5}; do
if curl -sf http://localhost:3001 > /dev/null 2>&1; then
FRONTEND_OK=true
break
fi
log "Frontend not ready yet, retry $i/5..."
sleep 5
done
if $BACKEND_OK && $FRONTEND_OK; then
log "=========================================="
log "Staging Deployment SUCCESSFUL!"
log "Frontend: http://192.168.0.202:3001"
log "Backend: http://192.168.0.202:8001/docs"
log "=========================================="
exit 0
else
log "=========================================="
log "Staging Deployment FAILED!"
log "Backend: $BACKEND_OK, Frontend: $FRONTEND_OK"
log "Check logs: docker compose -f docker-compose.staging.yml logs"
log "=========================================="
exit 1
fi