diff --git a/docker-compose.yml b/docker-compose.yml index 2742b5b..e286273 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -5,25 +5,22 @@ services: image: traefik:v2.5 container_name: traefik command: - - "--api.insecure=true" - - "--log.level=DEBUG" - - "--accesslog" - - "--entrypoints.web.address=:80" - - "--entrypoints.websecure.address=:443" # Still listen on 443, but traffic will be HTTP after passing through AEZA - - "--entrypoints.websecure.http.middlewares=ssl-redirect" # Redirect HTTP to HTTPS if required + - "--api.insecure=true" # Enable Traefik dashboard + - "--log.level=DEBUG" # Enable DEBUG level logs + - "--accesslog" # Enable access logs + - "--entrypoints.web.address=:80" # Listen on port 80 + - "--entrypoints.websecure.address=:443" # Listen on port 443 + - "--entrypoints.websecure.forwardedHeaders.insecure=true" # Allow forwarded headers ports: - - "80:80" # Expose port 80 for HTTP - - "443:443" # Expose port 443 for HTTPS (AEZA will handle SSL termination) - - "8080:8080" # Traefik dashboard, ensure it's secure if exposed + - "80:80" # Expose port 80 + - "443:443" # Expose port 443 + - "8080:8080" # Traefik Dashboard volumes: - - "/var/run/docker.sock:/var/run/docker.sock" - - "/path/to/acme.json:/acme.json" # Path to store Let's Encrypt certs (if using) + - "/var/run/docker.sock:/var/run/docker.sock" # Allow Traefik to interact with Docker networks: - web labels: - "traefik.enable=true" - - "traefik.http.routers.dashboard.rule=Host(`dash.embermarket.app`)" - - "traefik.http.services.dashboard.loadbalancer.server.port=3000" nextjs-app: build: @@ -31,15 +28,17 @@ services: dockerfile: Dockerfile container_name: nextjs-app-container expose: - - "3000" # Expose port 3000 internally (Traefik will route traffic to this port) + - "3000" # Expose port 3000 internally (not externally) labels: - "traefik.enable=true" - - "traefik.http.routers.dashboard.rule=Host(`dash.embermarket.app`)" # Match your domain - - "traefik.http.services.dashboard.loadbalancer.server.port=3000" + - "traefik.http.routers.nextjs-app.rule=Host(`dash.embermarket.app`)" + - "traefik.http.services.nextjs-app.loadbalancer.server.port=3000" environment: - NODE_ENV=production - NEXT_PUBLIC_API_URL=https://internal-api.inboxi.ng/api restart: unless-stopped + networks: + - web networks: web: