2018-06-26 12:28:47 +01:00
|
|
|
################################################################
|
|
|
|
# Global configuration
|
|
|
|
################################################################
|
|
|
|
|
|
|
|
# Enable debug mode
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
# Default: false
|
|
|
|
#
|
|
|
|
# debug = true
|
|
|
|
|
|
|
|
# Log level
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
# Default: "ERROR"
|
|
|
|
#
|
2020-04-24 14:22:29 +01:00
|
|
|
logLevel = "INFO"
|
2018-06-26 12:28:47 +01:00
|
|
|
|
|
|
|
# Entrypoints to be used by frontends that do not specify any entrypoint.
|
|
|
|
# Each frontend can specify its own entrypoints.
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
# Default: ["http"]
|
|
|
|
#
|
2020-04-24 14:22:29 +01:00
|
|
|
defaultEntryPoints = ["http", "https"]
|
|
|
|
|
|
|
|
# If set to true invalid SSL certificates are accepted for backends.
|
|
|
|
# This disables detection of man-in-the-middle attacks so should only be used on secure backend networks.
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
# Default: false
|
|
|
|
#
|
|
|
|
insecureSkipVerify = true
|
2018-06-26 12:28:47 +01:00
|
|
|
|
|
|
|
################################################################
|
|
|
|
# Entrypoints configuration
|
|
|
|
################################################################
|
|
|
|
|
|
|
|
# Entrypoints definition
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
# Default:
|
|
|
|
[entryPoints]
|
|
|
|
[entryPoints.http]
|
|
|
|
address = ":80"
|
2020-04-24 14:22:29 +01:00
|
|
|
compress = true
|
|
|
|
|
|
|
|
[entryPoints.http.redirect]
|
|
|
|
entryPoint = "https"
|
2018-06-26 12:28:47 +01:00
|
|
|
|
2020-04-24 14:22:29 +01:00
|
|
|
[entryPoints.https]
|
|
|
|
address = ":443"
|
|
|
|
compress = true
|
|
|
|
|
|
|
|
[entryPoints.https.tls]
|
|
|
|
|
|
|
|
[entryPoints.https.auth.forward]
|
|
|
|
address = "http://127.0.0.1:4181"
|
|
|
|
authResponseHeaders = ["X-Forwarded-User"]
|
|
|
|
|
|
|
|
[entryPoints.traefik]
|
|
|
|
address = ":8080"
|
2018-06-26 12:28:47 +01:00
|
|
|
|
|
|
|
################################################################
|
|
|
|
# Traefik logs configuration
|
|
|
|
################################################################
|
|
|
|
|
|
|
|
# Traefik logs
|
|
|
|
# Enabled by default and log to stdout
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
2020-04-24 14:22:29 +01:00
|
|
|
[traefikLog]
|
|
|
|
format = "json"
|
2018-06-26 12:28:47 +01:00
|
|
|
|
|
|
|
# Sets the filepath for the traefik log. If not specified, stdout will be used.
|
|
|
|
# Intermediate directories are created if necessary.
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
# Default: os.Stdout
|
|
|
|
#
|
|
|
|
# filePath = "log/traefik.log"
|
|
|
|
|
|
|
|
# Format is either "json" or "common".
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
# Default: "common"
|
|
|
|
#
|
|
|
|
# format = "common"
|
|
|
|
|
|
|
|
################################################################
|
|
|
|
# Access logs configuration
|
|
|
|
################################################################
|
|
|
|
|
|
|
|
# Enable access logs
|
|
|
|
# By default it will write to stdout and produce logs in the textual
|
|
|
|
# Common Log Format (CLF), extended with additional fields.
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# [accessLog]
|
|
|
|
|
|
|
|
# Sets the file path for the access log. If not specified, stdout will be used.
|
|
|
|
# Intermediate directories are created if necessary.
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
# Default: os.Stdout
|
|
|
|
#
|
|
|
|
# filePath = "/path/to/log/log.txt"
|
|
|
|
|
|
|
|
# Format is either "json" or "common".
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
# Default: "common"
|
|
|
|
#
|
|
|
|
# format = "common"
|
|
|
|
|
|
|
|
################################################################
|
|
|
|
# API and dashboard configuration
|
|
|
|
################################################################
|
|
|
|
|
|
|
|
# Enable API and dashboard
|
|
|
|
[api]
|
|
|
|
|
|
|
|
# Name of the related entry point
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
# Default: "traefik"
|
|
|
|
#
|
|
|
|
# entryPoint = "traefik"
|
|
|
|
|
|
|
|
# Enabled Dashboard
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
# Default: true
|
|
|
|
#
|
|
|
|
# dashboard = false
|
|
|
|
|
|
|
|
################################################################
|
|
|
|
# Ping configuration
|
|
|
|
################################################################
|
|
|
|
|
|
|
|
# Enable ping
|
|
|
|
[ping]
|
|
|
|
|
|
|
|
# Name of the related entry point
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
# Default: "traefik"
|
|
|
|
#
|
|
|
|
# entryPoint = "traefik"
|
|
|
|
|
|
|
|
################################################################
|
|
|
|
# Docker configuration backend
|
|
|
|
################################################################
|
|
|
|
|
2020-04-24 14:22:29 +01:00
|
|
|
# Enable Kubernetes configuration backend
|
|
|
|
[kubernetes]
|
|
|
|
|
|
|
|
[acme]
|
|
|
|
KeyType = "RSA4096"
|
|
|
|
email = "you@example.com"
|
|
|
|
storage = "/acme/acme.json"
|
|
|
|
entryPoint = "https"
|
|
|
|
onHostRule = true
|
|
|
|
acmeLogging = true
|
|
|
|
|
|
|
|
[acme.httpChallenge]
|
|
|
|
entryPoint = "http"
|