services: traefik: image: traefik:v3.6 container_name: traefik restart: unless-stopped ports: - "80:80" - "443:443" - "${TRAEFIK_DASHBOARD_PORT}:8080" volumes: - /var/run/docker.sock:/var/run/docker.sock:ro - ${STORAGE_PATH}/traefik/certs:/certs:rw - ${STORAGE_PATH}/traefik/dynamic:/dynamic:ro - ${STORAGE_PATH}/traefik/letsencrypt:/letsencrypt networks: - web security_opt: - no-new-privileges:true labels: - "traefik.enable=true" - "traefik.http.middlewares.dashboard-auth.basicauth.users=${DASHBOARD_BASIC_AUTH}" - "traefik.http.routers.dashboard.entrypoints=websecure" - "traefik.http.routers.dashboard.middlewares=dashboard-auth@docker" - "traefik.http.routers.dashboard.rule=Host(`dashboard.${DOMAIN}`)" - "traefik.http.routers.dashboard.service=api@internal" - "traefik.http.routers.dashboard.tls=true" - "traefik.http.routers.dashboard.tls.certresolver=letsencrypt" command: - "--entrypoints.web.address=:80" - "--entrypoints.web.http.redirections.entrypoint.to=websecure" - "--entrypoints.web.http.redirections.entrypoint.scheme=https" - "--entrypoints.websecure.address=:443" - "--providers.docker=true" - "--providers.docker.exposedbydefault=false" - "--providers.docker.network=web" - "--api.dashboard=true" - "--api.insecure=false" - "--certificatesresolvers.letsencrypt.acme.httpchallenge=true" - "--certificatesresolvers.letsencrypt.acme.httpchallenge.entrypoint=web" - "--certificatesresolvers.letsencrypt.acme.email=${ACME_EMAIL}" - "--certificatesresolvers.letsencrypt.acme.storage=/certs/acme.json" - "--metrics.prometheus=true" - "--accesslog=true" - "--providers.file.directory=/dynamic" - "--providers.file.watch=true" networks: web: external: true