Spaces:
Paused
Paused
| version: "3.8" | |
| services: | |
| # FastAPI Application | |
| legal-dashboard: | |
| build: | |
| context: . | |
| dockerfile: Dockerfile | |
| container_name: legal_dashboard_app | |
| restart: unless-stopped | |
| ports: | |
| - "8000:8000" | |
| networks: | |
| - app_network | |
| volumes: | |
| # Create host directories with proper permissions first | |
| - ./data:/app/data:rw | |
| - ./cache:/app/cache:rw | |
| - ./logs:/app/logs:rw | |
| - ./uploads:/app/uploads:rw | |
| - ./backups:/app/backups:rw | |
| # Mount frontend directory explicitly | |
| - ./frontend:/app/frontend:ro | |
| environment: | |
| - DATABASE_DIR=/app/data | |
| - DATABASE_PATH=/app/data/legal_dashboard.db | |
| - TRANSFORMERS_CACHE=/app/cache | |
| - HF_HOME=/app/cache | |
| - LOG_LEVEL=INFO | |
| - ENVIRONMENT=production | |
| - JWT_SECRET_KEY=${JWT_SECRET_KEY:-your-secret-key-change-in-production} | |
| - PYTHONPATH=/app | |
| - PYTHONUNBUFFERED=1 | |
| # Fix Redis connection | |
| - REDIS_URL=redis://redis:6379/0 | |
| - REDIS_HOST=redis | |
| - REDIS_PORT=6379 | |
| healthcheck: | |
| test: ["CMD-SHELL", "curl -fs http://localhost:8000/ping || exit 1"] | |
| interval: 45s | |
| timeout: 30s | |
| retries: 10 | |
| start_period: 180s | |
| depends_on: | |
| redis: | |
| condition: service_healthy | |
| # Redis for caching and sessions | |
| redis: | |
| image: redis:7-alpine | |
| container_name: legal_dashboard_redis | |
| restart: unless-stopped | |
| networks: | |
| - app_network | |
| volumes: | |
| - redis_data:/data | |
| command: redis-server --appendonly yes --maxmemory 256mb --maxmemory-policy allkeys-lru | |
| healthcheck: | |
| test: ["CMD", "redis-cli", "ping"] | |
| interval: 30s | |
| timeout: 10s | |
| retries: 3 | |
| start_period: 30s | |
| # Don't expose Redis port to host for security | |
| expose: | |
| - "6379" | |
| # Nginx Reverse Proxy (Optional but recommended for production) | |
| nginx: | |
| image: nginx:alpine | |
| container_name: legal_dashboard_nginx | |
| restart: unless-stopped | |
| ports: | |
| - "80:80" | |
| - "443:443" | |
| volumes: | |
| - ./nginx.conf:/etc/nginx/conf.d/default.conf:ro | |
| - ./frontend:/usr/share/nginx/html/static:ro | |
| - ./logs/nginx:/var/log/nginx | |
| depends_on: | |
| - legal-dashboard | |
| networks: | |
| - app_network | |
| # Backup Service | |
| backup: | |
| image: alpine:latest | |
| container_name: legal_dashboard_backup | |
| restart: unless-stopped | |
| volumes: | |
| - ./data:/app/data:ro | |
| - ./backups:/app/backups:rw | |
| - ./logs:/app/logs:ro | |
| command: | | |
| sh -c " | |
| echo 'Starting backup service...' && | |
| mkdir -p /app/backups && | |
| while true; do | |
| echo 'Creating backup...' && | |
| timestamp=$$(date +%Y%m%d_%H%M%S) && | |
| tar -czf /app/backups/backup-$$timestamp.tar.gz -C /app data logs 2>/dev/null || echo 'Backup failed' && | |
| echo 'Cleaning old backups...' && | |
| find /app/backups -name 'backup-*.tar.gz' -mtime +7 -delete 2>/dev/null || echo 'Cleanup completed' && | |
| echo 'Backup cycle completed. Sleeping for 24 hours...' && | |
| sleep 86400 | |
| done | |
| " | |
| networks: | |
| - app_network | |
| networks: | |
| app_network: | |
| driver: bridge | |
| ipam: | |
| config: | |
| - subnet: 172.20.0.0/16 | |
| volumes: | |
| redis_data: | |
| driver: local |