version: '3' services: traefik: image: traefik:latest container_name: traefik restart: unless-stopped security_opt: - no-new-privileges:true networks: - proxy ports: - 80:80 - 443:443 environment: - CF_DNS_API_TOKEN=YOUR_EDITZONEDNS_API_TOKEN_FROM_CLOUDFLARE # If you choose to use an API Key instead of a Token, specify your email as well # - CF_API_EMAIL=user@example.com # - CF_API_KEY=YOUR_API_KEY volumes: - /etc/localtime:/etc/localtime:ro - /var/run/docker.sock:/var/run/docker.sock:ro - ./data/traefik.yml:/traefik.yml:ro - ./data/acme.json:/acme.json - ./data/config.yml:/config.yml:ro - traefik-logs:/var/log/traefik labels: - "traefik.enable=true" - "traefik.http.routers.traefik.entrypoints=http" - "traefik.http.routers.traefik.rule=Host(`traefik.crsmthw.com`)" - "traefik.http.middlewares.traefik-auth.basicauth.users=USERNAME:YOUR_HASHED_PASSWORD" - "traefik.http.middlewares.traefik-https-redirect.redirectscheme.scheme=https" - "traefik.http.middlewares.sslheader.headers.customrequestheaders.X-Forwarded-Proto=https" - "traefik.http.routers.traefik.middlewares=traefik-https-redirect" - "traefik.http.routers.traefik-secure.entrypoints=https" - "traefik.http.routers.traefik-secure.rule=Host(`traefik.EXAMPLE.com`)" - "traefik.http.routers.traefik-secure.middlewares=traefik-auth" - "traefik.http.routers.traefik-secure.tls=true" - "traefik.http.routers.traefik-secure.tls.certresolver=cloudflare" - "traefik.http.routers.traefik-secure.tls.domains[0].main=EXAMPLE.com" - "traefik.http.routers.traefik-secure.tls.domains[0].sans=*.EXAMPLE.com" - "traefik.http.routers.traefik-secure.service=api@internal" networks: proxy: external: true volumes: traefik-logs: