# =========================================== # Production Docker Compose # Optimized for production deployment # =========================================== services: app: build: context: . dockerfile: Dockerfile container_name: netflix-scraper-api restart: unless-stopped ports: - "${PORT:-3000}:3000" environment: - NODE_ENV=production - PORT=3000 - POSTGRES_HOST=postgres - POSTGRES_PORT=5432 - POSTGRES_USER=${POSTGRES_USER} - POSTGRES_PASSWORD=${POSTGRES_PASSWORD} - POSTGRES_DB=${POSTGRES_DB} - REDIS_HOST=redis - REDIS_PORT=6379 - REDIS_TTL_SECONDS=${REDIS_TTL_SECONDS:-604800} - RATE_LIMIT_WINDOW_MS=${RATE_LIMIT_WINDOW_MS:-60000} - RATE_LIMIT_MAX_REQUESTS=${RATE_LIMIT_MAX_REQUESTS:-30} - API_KEY_WEB=${API_KEY_WEB} - API_KEY_MOBILE=${API_KEY_MOBILE} - API_KEY_ADMIN=${API_KEY_ADMIN} depends_on: postgres: condition: service_healthy redis: condition: service_healthy healthcheck: test: ["CMD", "wget", "--no-verbose", "--tries=1", "--spider", "http://localhost:3000/health"] interval: 30s timeout: 10s retries: 3 start_period: 30s networks: - netflix-scraper-network security_opt: - no-new-privileges:true read_only: true tmpfs: - /tmp postgres: image: postgres:16-alpine container_name: netflix-scraper-postgres restart: unless-stopped environment: - POSTGRES_USER=${POSTGRES_USER} - POSTGRES_PASSWORD=${POSTGRES_PASSWORD} - POSTGRES_DB=${POSTGRES_DB} volumes: - postgres_data:/var/lib/postgresql/data healthcheck: test: ["CMD-SHELL", "pg_isready -U ${POSTGRES_USER} -d ${POSTGRES_DB}"] interval: 10s timeout: 5s retries: 5 start_period: 10s networks: - netflix-scraper-network security_opt: - no-new-privileges:true redis: image: redis:7-alpine container_name: netflix-scraper-redis restart: unless-stopped command: redis-server --appendonly yes volumes: - redis_data:/data healthcheck: test: ["CMD", "redis-cli", "ping"] interval: 10s timeout: 5s retries: 5 start_period: 5s networks: - netflix-scraper-network security_opt: - no-new-privileges:true volumes: postgres_data: redis_data: networks: netflix-scraper-network: driver: bridge