Files
docker-compose/.archived/traefik/compose.yaml
T

85 lines
2.5 KiB
YAML
Raw Normal View History

2025-07-21 12:37:07 +05:30
services:
2025-07-25 22:36:29 +05:30
traefik_socket_proxy:
container_name: traefik_socket_proxy
image: ghcr.io/11notes/socket-proxy:2.1.3
restart: unless-stopped
read_only: true
user: ${PUID}:${PGID}
environment:
TZ: ${TZ}
volumes:
- /run/docker.sock:/run/docker.sock:ro
- socket-proxy:/run/proxy
networks:
- frontend
2025-07-21 12:37:07 +05:30
traefik:
container_name: traefik
image: docker.io/library/traefik:v3.5.0
2025-07-21 12:37:07 +05:30
restart: unless-stopped
2025-07-25 22:36:29 +05:30
depends_on:
traefik_socket_proxy:
condition: service_healthy
2025-07-21 12:37:07 +05:30
security_opt:
- no-new-privileges:true
secrets:
- cf_api_token
environment:
2025-07-25 23:23:42 +05:30
- CF_DNS_API_TOKEN_FILE=/run/secrets/cf_api_token
2025-07-21 12:37:07 +05:30
volumes:
2025-07-21 12:38:41 +05:30
- ${APPDATA_PATH}/traefik/data/acme.json:/acme.json
2025-07-21 15:48:35 +05:30
- ${APPDATA_PATH}/traefik/logs:/var/log/traefik
2025-07-21 12:37:07 +05:30
- /etc/localtime:/etc/localtime:ro
2025-07-25 22:36:29 +05:30
- socket-proxy:/var/run
2025-07-21 12:37:07 +05:30
ports:
- 80:80
- 443:443
- 443:443/udp
networks:
- frontend
2025-07-27 18:30:47 +05:30
command:
- --api.debug=true
2025-07-27 18:51:34 +05:30
- --serversTransport.insecureSkipVerify=true
# Entrypoints
2025-07-27 18:30:47 +05:30
- --entrypoints.web.address=:80
- --entrypoints.web.http.redirections.entrypoint.to=websecure
- --entrypoints.web.http.redirections.entrypoint.scheme=https
- --entrypoints.websecure.address=:443
- --entrypoints.websecure.http.tls.certresolver=letsencrypt
- --entrypoints.websecure.http.tls.domains[0].main=${DOMAIN}
- --entrypoints.websecure.http.tls.domains[0].sans=*.${DOMAIN}
2025-07-27 18:51:34 +05:30
# Providers
2025-07-27 18:30:47 +05:30
- --providers.docker.endpoint=unix:///var/run/docker.sock
- --providers.docker.exposedbydefault=false
2025-07-27 18:51:34 +05:30
- --providers.docker.constraints=Label(`traefik-instance`,`${TRAEFIK_INSTANCE}`)
# Certificates Resolvers
2025-07-27 18:30:47 +05:30
- --certificatesresolvers.letsencrypt.acme.email=${EMAIL}
- --certificatesresolvers.letsencrypt.acme.storage=acme.json
- --certificatesresolvers.letsencrypt.acme.caserver=https://acme-v02.api.letsencrypt.org/directory
- --certificatesresolvers.letsencrypt.acme.dnschallenge.provider=cloudflare
- --certificatesresolvers.letsencrypt.acme.dnschallenge.resolvers=1.1.1.1:53,1.0.0.1:53
2025-07-27 18:51:34 +05:30
# Log
2025-07-27 18:30:47 +05:30
- --log.level=INFO
- --log.filepath=/var/log/traefik/traefik.log
- --log.maxsize=10
- --log.maxbackups=5
2025-07-27 18:51:34 +05:30
# Access Log
2025-07-27 18:30:47 +05:30
- --accesslog.filepath=/var/log/traefik/access.log
- --accesslog.fields.names.StartUTC=drop
2025-07-21 12:37:07 +05:30
networks:
frontend:
external: true
secrets:
cf_api_token:
2025-07-21 15:48:35 +05:30
file: ${APPDATA_PATH}/traefik/secrets/cf_api_token
2025-07-25 22:36:29 +05:30
volumes:
socket-proxy: