Spaces:
Paused
Paused
File size: 3,242 Bytes
8d3cb40 272dc7c 8d3cb40 272dc7c 8d3cb40 272dc7c a7c6b5b 8d3cb40 a7c6b5b 8d3cb40 272dc7c 8d3cb40 272dc7c 8d3cb40 272dc7c 8d3cb40 272dc7c 8d3cb40 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 |
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 |