version: '3' services: traefik: image: traefik:latest container_name: traefik restart: unless-stopped security_opt: - no-new-privileges:true networks: proxy: ports: - 80:80 - 81:81 # external http - 443:443 - 444:444 # external https environment: - CF_API_EMAIL=your@email.com - CF_DNS_API_TOKEN=super-secure-token # - CF_API_KEY=YOU_API_KEY # be sure to use the correct one depending on if you are using a token or key volumes: - /etc/localtime:/etc/localtime:ro - /var/run/docker.sock:/var/run/docker.sock:ro - /home/ubuntu/docker/traefik/traefik.yml:/traefik.yml:ro - /home/ubuntu/docker/traefik/acme.json:/acme.json - /home/ubuntu/docker/traefik/config.yml:/config.yml:ro - /home/ubuntu/docker/traefik/logs:/var/log/traefik labels: - "traefik.enable=true" - "traefik.http.routers.traefik.entrypoints=http" # restricts dashboard to internal entrypoint - "traefik.http.routers.traefik.rule=Host(`traefik-docker.yourdomain.com`)" - "traefik.http.middlewares.traefik-auth.basicauth.users=admin:password-hash" - "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-docker.yourdomain.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=yourdomain.co.uk" - "traefik.http.routers.traefik-secure.tls.domains[0].sans=*.yourdomain.co.uk" - "traefik.http.routers.traefik-secure.service=api@internal" networks: proxy: external: true