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