Update docker-compose.yml
This commit is contained in:
@@ -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.routers.nextjs-app.rule=Host(`dash.embermarket.app`) || PathPrefix(`/`)"
|
||||||
- "traefik.http.services.nextjs-app.loadbalancer.server.port=3000"
|
- "traefik.http.services.nextjs-app.loadbalancer.server.port=3000"
|
||||||
|
- "traefik.http.routers.nextjs-app.middlewares=ip-whitelist@file"
|
||||||
# IP Whitelist middleware for the Next.js app
|
# Add fallback entrypoint if needed
|
||||||
- "traefik.http.routers.nextjs-app.middlewares=ip-whitelist@file" # Use @file to reference middleware from a file provider
|
- "traefik.http.routers.nextjs-app.entrypoints=websecure"
|
||||||
|
networks:
|
||||||
# Define the IP whitelist middleware for the Next.js app
|
- web
|
||||||
- "traefik.http.middlewares.ip-whitelist@file.ipWhiteList.sourcerange=212.113.116.6,194.26.229.41,138.124.13.13" # Allowed IPs
|
|
||||||
|
|
||||||
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:
|
||||||
|
|||||||
Reference in New Issue
Block a user