# docker-compose.prod.yml -- Production environment override # Usage: docker compose -f docker-compose.yml -f docker-compose.prod.yml --env-file .env.prod up -d services: api: build: context: . dockerfile: infrastructure/docker/Dockerfile.api container_name: tod_api env_file: .env.prod environment: ENVIRONMENT: production LOG_LEVEL: info GUNICORN_WORKERS: "2" command: ["gunicorn", "app.main:app", "--config", "gunicorn.conf.py"] volumes: - ./docker-data/git-store:/data/git-store depends_on: postgres: condition: service_healthy redis: condition: service_healthy nats: condition: service_healthy deploy: resources: limits: memory: 512M restart: unless-stopped logging: driver: json-file options: max-size: "10m" max-file: "3" networks: - tod poller: build: context: ./poller dockerfile: ./Dockerfile container_name: tod_poller env_file: .env.prod environment: ENVIRONMENT: production LOG_LEVEL: info TUNNEL_PORT_MIN: 49000 TUNNEL_PORT_MAX: 49100 TUNNEL_IDLE_TIMEOUT: 300 SSH_RELAY_PORT: 8080 SSH_IDLE_TIMEOUT: 900 SSH_MAX_SESSIONS: 200 SSH_MAX_PER_USER: 10 SSH_MAX_PER_DEVICE: 20 ports: - "127.0.0.1:49000-49100:49000-49100" ulimits: nofile: soft: 8192 hard: 8192 depends_on: postgres: condition: service_healthy redis: condition: service_healthy nats: condition: service_healthy healthcheck: test: ["CMD-SHELL", "wget --spider -q http://localhost:8080/healthz || exit 1"] interval: 30s timeout: 3s retries: 3 deploy: resources: limits: memory: 512M # increased from 256M for tunnel/SSH overhead restart: unless-stopped logging: driver: json-file options: max-size: "10m" max-file: "3" networks: - tod frontend: build: context: . dockerfile: infrastructure/docker/Dockerfile.frontend container_name: tod_frontend ports: - "80:80" depends_on: - api deploy: resources: limits: memory: 64M restart: unless-stopped networks: - tod