diff --git a/traefik/compose.yml b/traefik/compose.yml index e69de29..bdf0545 100644 --- a/traefik/compose.yml +++ b/traefik/compose.yml @@ -0,0 +1,48 @@ +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: