Update docker-compose.yml

This commit is contained in:
NotII
2025-03-09 01:35:55 +00:00
parent 1625718fc7
commit 134871404b

View File

@@ -3,50 +3,45 @@ version: '3.8'
services: services:
traefik: traefik:
image: traefik:v2.5 image: traefik:v2.5
container_name: traefik
command: command:
- "--api.insecure=true" # Enable Traefik dashboard (optional) - "--api.insecure=true"
- "--log.level=DEBUG" # Enable DEBUG level logs - "--log.level=DEBUG"
- "--accesslog" # Enable access logs - "--accesslog"
- "--entrypoints.web.address=:80" # Listen on port 80 - "--providers.docker=true"
- "--entrypoints.websecure.address=:443" # Listen on port 443 - "--providers.docker.network=web"
- "--entrypoints.websecure.forwardedHeaders.insecure=true" # Allow forwarded headers - "--entrypoints.web.address=:80"
- "--entrypoints.websecure.address=:443"
- "--entrypoints.websecure.forwardedHeaders.trustedIPs=212.113.116.6,194.26.229.41,138.124.13.13"
ports: ports:
- "80:80" # Expose port 80 - "80:80"
- "443:443" # Expose port 443 - "443:443"
- "8080:8080" # Traefik Dashboard (optional) - "8080:8080"
volumes: volumes:
- "/var/run/docker.sock:/var/run/docker.sock" # Allow Traefik to interact with Docker - "/var/run/docker.sock:/var/run/docker.sock"
networks: networks:
- web - web
labels:
- "traefik.enable=true"
nextjs-app: nextjs-app:
build: build:
context: . # Path to your project context: .
dockerfile: Dockerfile dockerfile: Dockerfile
container_name: nextjs-app-container container_name: nextjs-app-container
expose: expose:
- "3000" # Expose port 3000 internally (not externally) - "3000"
labels: labels:
- "traefik.enable=true" - "traefik.enable=true"
- "traefik.http.routers.nextjs-app.rule=Host(`dash.embermarket.app`)" # Use either Host header or alternative routing
- "traefik.http.services.nextjs-app.loadbalancer.server.port=3000" - "traefik.http.routers.nextjs-app.rule=Host(`dash.embermarket.app`) || PathPrefix(`/`)"
- "traefik.http.services.nextjs-app.loadbalancer.server.port=3000"
# IP Whitelist middleware for the Next.js app - "traefik.http.routers.nextjs-app.middlewares=ip-whitelist@file"
- "traefik.http.routers.nextjs-app.middlewares=ip-whitelist@file" # Use @file to reference middleware from a file provider # Add fallback entrypoint if needed
- "traefik.http.routers.nextjs-app.entrypoints=websecure"
# Define the IP whitelist middleware for the Next.js app networks:
- "traefik.http.middlewares.ip-whitelist@file.ipWhiteList.sourcerange=212.113.116.6,194.26.229.41,138.124.13.13" # Allowed IPs - web
environment:
environment: - NODE_ENV=production
- NODE_ENV=production - NEXT_PUBLIC_API_URL=https://internal-api.inboxi.ng/api
- NEXT_PUBLIC_API_URL=https://internal-api.inboxi.ng/api restart: unless-stopped
restart: unless-stopped
networks:
- web
networks: networks:
web: web: