Skip to content

Instantly share code, notes, and snippets.

@maxheadroom
Last active January 28, 2024 20:04
Show Gist options
  • Save maxheadroom/7ea4a6ac1760881849e6a11def04e833 to your computer and use it in GitHub Desktop.
Save maxheadroom/7ea4a6ac1760881849e6a11def04e833 to your computer and use it in GitHub Desktop.
Traefik Reverse Proxy docker.yaml
---
version: "3.0"
networks:
web:
external: true
bridge:
services:
traefik:
container_name: traefik
image: "traefik:2.8.8"
restart: always
dns:
- 192.168.75.1
- 8.8.8.8
command:
- "--accesslog=true"
- "--api=true"
- "--api.dashboard=true"
- "--api.insecure=false"
- "--certificatesresolvers.myresolver.acme.tlschallenge=true"
- "--certificatesresolvers.myresolver.acme.caserver=https://acme-v02.api.letsencrypt.org/directory"
- "[email protected]"
- "--certificatesresolvers.myresolver.acme.storage=/letsencrypt/acme.json"
- "--certificatesresolvers.letsencrypt.acme.httpchallenge=true"
- "--certificatesresolvers.letsencrypt.acme.httpchallenge.entrypoint=web"
- "[email protected]"
- "--certificatesresolvers.letsencrypt.acme.storage=/letsencrypt/web-acme.json"
- "--entrypoints.web.address=:80"
- "--entrypoints.websecure.address=:443"
- "--providers.docker.exposedbydefault=false"
- "--providers.docker.network=web"
- "--providers.docker=true"
- "--providers.file.directory=/rules"
- "--providers.file.watch=true"
ports:
- "80:80"
- "443:443"
labels:
- "traefik.enable=true"
- "traefik.http.routers.traefik.rule=(Host(`homehosting.aws.example.com`) && (PathPrefix(`/api`) || PathPrefix(`/dashboard`)))"
- "traefik.http.routers.traefik.service=api@internal"
- "traefik.http.routers.traefik.tls.certresolver=letsencrypt"
- "traefik.http.routers.traefik.entrypoints=websecure"
- "traefik.http.routers.traefik.middlewares=root"
- 'traefik.http.middlewares.admin.basicauth.users=root:$$apr1$$6RrUIuyd$$A9KS3c5FxlComHMo.Tcq9.'
- "traefik.http.routers.http-catchall.rule=hostregexp(`{host:.+}`)"
- "traefik.http.routers.http-catchall.entrypoints=web"
- "traefik.http.routers.http-catchall.middlewares=redirect-to-https@docker"
- "traefik.http.middlewares.redirect-to-https.redirectscheme.scheme=https"
volumes:
- "./letsencrypt:/letsencrypt"
- "./rules:/rules:ro"
- "/var/run/docker.sock:/var/run/docker.sock:ro"
networks:
- web
- bridge
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment