2015-09-14 15:38:58 +02:00
|
|
|
################################################################
|
|
|
|
# Global configuration
|
|
|
|
################################################################
|
|
|
|
|
2016-02-01 16:09:13 +01:00
|
|
|
# Entrypoints definition
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
# Default:
|
|
|
|
# [entryPoints]
|
|
|
|
# [entryPoints.http]
|
|
|
|
# address = ":80"
|
|
|
|
#
|
|
|
|
# To redirect an http entrypoint to an https entrypoint (with SNI support):
|
|
|
|
# [entryPoints]
|
|
|
|
# [entryPoints.http]
|
|
|
|
# address = ":80"
|
|
|
|
# [entryPoints.http.redirect]
|
|
|
|
# entryPoint = "https"
|
|
|
|
# [entryPoints.https]
|
|
|
|
# address = ":443"
|
|
|
|
# [entryPoints.https.tls]
|
|
|
|
# [[entryPoints.https.tls.certificates]]
|
|
|
|
# CertFile = "integration/fixtures/https/snitest.com.cert"
|
|
|
|
# KeyFile = "integration/fixtures/https/snitest.com.key"
|
|
|
|
# [[entryPoints.https.tls.certificates]]
|
|
|
|
# CertFile = "integration/fixtures/https/snitest.org.cert"
|
|
|
|
# KeyFile = "integration/fixtures/https/snitest.org.key"
|
|
|
|
#
|
|
|
|
# To redirect an entrypoint rewriting the URL:
|
|
|
|
# [entryPoints]
|
|
|
|
# [entryPoints.http]
|
|
|
|
# address = ":80"
|
|
|
|
# [entryPoints.http.redirect]
|
|
|
|
# regex = "^http://localhost/(.*)"
|
|
|
|
# replacement = "http://mydomain/$1"
|
|
|
|
|
|
|
|
# Entrypoints to be used by frontends that do not specify any entrypoint.
|
|
|
|
# Each frontend can specify its own entrypoints.
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
# Default: ["http"]
|
|
|
|
#
|
|
|
|
# defaultEntryPoints = ["http", "https"]
|
2015-09-14 15:38:58 +02:00
|
|
|
|
|
|
|
# Timeout in seconds.
|
|
|
|
# Duration to give active requests a chance to finish during hot-reloads
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
# Default: 10
|
|
|
|
#
|
|
|
|
# graceTimeOut = 10
|
|
|
|
|
|
|
|
# Traefik logs file
|
2015-09-24 14:32:37 +02:00
|
|
|
# If not defined, logs to stdout
|
2015-09-14 15:38:58 +02:00
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# traefikLogsFile = "log/traefik.log"
|
|
|
|
|
|
|
|
# Access logs file
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# accessLogsFile = "log/access.log"
|
|
|
|
|
|
|
|
# Log level
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
# Default: "ERROR"
|
|
|
|
#
|
|
|
|
# logLevel = "ERROR"
|
|
|
|
|
2015-10-08 17:56:45 +02:00
|
|
|
# Backends throttle duration: minimum duration between 2 events from providers
|
|
|
|
# before applying a new configuration. It avoids unnecessary reloads if multiples events
|
|
|
|
# are sent in a short amount of time.
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
# Default: "2s"
|
|
|
|
#
|
2015-10-17 14:14:20 +02:00
|
|
|
# ProvidersThrottleDuration = "5s"
|
2015-10-08 17:56:45 +02:00
|
|
|
|
2016-02-09 22:29:01 +01:00
|
|
|
# If non-zero, controls the maximum idle (keep-alive) to keep per-host. If zero, DefaultMaxIdleConnsPerHost is used.
|
|
|
|
# If you encounter 'too many open files' errors, you can either change this value, or change `ulimit` value.
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
# Default: http.DefaultMaxIdleConnsPerHost
|
|
|
|
#
|
|
|
|
# MaxIdleConnsPerHost = 200
|
|
|
|
|
2015-10-08 17:56:45 +02:00
|
|
|
|
2015-09-14 15:38:58 +02:00
|
|
|
################################################################
|
|
|
|
# Web configuration backend
|
|
|
|
################################################################
|
|
|
|
|
|
|
|
# Enable web configuration backend
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# [web]
|
|
|
|
|
|
|
|
# Web administration port
|
|
|
|
#
|
|
|
|
# Required
|
|
|
|
#
|
|
|
|
# address = ":8080"
|
|
|
|
|
2015-09-22 21:00:29 +02:00
|
|
|
# SSL certificate and key used
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# CertFile = "traefik.crt"
|
|
|
|
# KeyFile = "traefik.key"
|
2016-01-13 22:46:44 +01:00
|
|
|
#
|
|
|
|
# Set REST API to read-only mode
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
# ReadOnly = false
|
2015-09-22 21:00:29 +02:00
|
|
|
|
2015-09-14 15:38:58 +02:00
|
|
|
|
|
|
|
################################################################
|
|
|
|
# File configuration backend
|
|
|
|
################################################################
|
|
|
|
|
|
|
|
# Enable file configuration backend
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# [file]
|
|
|
|
|
|
|
|
# Rules file
|
|
|
|
# If defined, traefik will load rules from this file,
|
|
|
|
# otherwise, it will load rules from current file (cf Sample rules below).
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# filename = "rules.toml"
|
|
|
|
|
|
|
|
# Enable watch file changes
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# watch = true
|
|
|
|
|
|
|
|
|
|
|
|
################################################################
|
|
|
|
# Docker configuration backend
|
|
|
|
################################################################
|
|
|
|
|
|
|
|
# Enable Docker configuration backend
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# [docker]
|
|
|
|
|
|
|
|
# Docker server endpoint. Can be a tcp or a unix socket endpoint.
|
|
|
|
#
|
|
|
|
# Required
|
|
|
|
#
|
|
|
|
# endpoint = "unix:///var/run/docker.sock"
|
|
|
|
|
|
|
|
# Default domain used.
|
|
|
|
# Can be overridden by setting the "traefik.domain" label on a container.
|
|
|
|
#
|
|
|
|
# Required
|
|
|
|
#
|
|
|
|
# domain = "docker.localhost"
|
|
|
|
|
2015-09-15 00:03:53 +02:00
|
|
|
# Enable watch docker changes
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# watch = true
|
|
|
|
|
2015-09-14 15:38:58 +02:00
|
|
|
# Override default configuration template. For advanced users :)
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# filename = "docker.tmpl"
|
|
|
|
|
2015-11-20 23:05:06 +08:00
|
|
|
# Enable docker TLS connection
|
|
|
|
#
|
2016-01-18 11:52:18 +01:00
|
|
|
# Optional
|
|
|
|
#
|
2015-11-20 23:05:06 +08:00
|
|
|
# [docker.tls]
|
|
|
|
# ca = "/etc/ssl/ca.crt"
|
|
|
|
# cert = "/etc/ssl/docker.crt"
|
|
|
|
# key = "/etc/ssl/docker.key"
|
|
|
|
# insecureskipverify = true
|
|
|
|
|
2015-09-14 15:38:58 +02:00
|
|
|
|
|
|
|
################################################################
|
|
|
|
# Mesos/Marathon configuration backend
|
|
|
|
################################################################
|
|
|
|
|
|
|
|
# Enable Marathon configuration backend
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# [marathon]
|
|
|
|
|
|
|
|
# Marathon server endpoint.
|
|
|
|
# You can also specify multiple endpoint for Marathon:
|
|
|
|
# endpoint := "http://10.241.1.71:8080,10.241.1.72:8080,10.241.1.73:8080"
|
|
|
|
#
|
|
|
|
# Required
|
|
|
|
#
|
|
|
|
# endpoint = "http://127.0.0.1:8080"
|
|
|
|
|
|
|
|
# Enable watch Marathon changes
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# watch = true
|
|
|
|
|
|
|
|
# Default domain used.
|
|
|
|
# Can be overridden by setting the "traefik.domain" label on an application.
|
|
|
|
#
|
|
|
|
# Required
|
|
|
|
#
|
|
|
|
# domain = "marathon.localhost"
|
|
|
|
|
|
|
|
# Override default configuration template. For advanced users :)
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# filename = "marathon.tmpl"
|
|
|
|
|
2016-01-18 11:52:18 +01:00
|
|
|
# Enable Marathon basic authentication
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# [marathon.basic]
|
|
|
|
# httpBasicAuthUser = "foo"
|
|
|
|
# httpBasicPassword = "bar"
|
|
|
|
|
2016-02-09 23:10:24 +01:00
|
|
|
# TLS client configuration. https://golang.org/pkg/crypto/tls/#Config
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# [marathon.TLS]
|
|
|
|
# InsecureSkipVerify = true
|
|
|
|
|
2015-09-14 15:38:58 +02:00
|
|
|
|
2015-09-21 18:05:56 +02:00
|
|
|
################################################################
|
|
|
|
# Consul KV configuration backend
|
|
|
|
################################################################
|
|
|
|
|
|
|
|
# Enable Consul KV configuration backend
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# [consul]
|
|
|
|
|
|
|
|
# Consul server endpoint
|
|
|
|
#
|
|
|
|
# Required
|
|
|
|
#
|
2015-09-25 11:44:19 +02:00
|
|
|
# endpoint = "127.0.0.1:8500"
|
2015-09-21 18:05:56 +02:00
|
|
|
|
|
|
|
# Enable watch Consul changes
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# watch = true
|
|
|
|
|
|
|
|
# Prefix used for KV store.
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
2015-10-01 12:04:25 +02:00
|
|
|
# prefix = "/traefik"
|
2015-09-21 18:05:56 +02:00
|
|
|
|
|
|
|
# Override default configuration template. For advanced users :)
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# filename = "consul.tmpl"
|
|
|
|
|
2016-02-19 17:10:48 +01:00
|
|
|
# Enable consul TLS connection
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# [consul.tls]
|
|
|
|
# ca = "/etc/ssl/ca.crt"
|
|
|
|
# cert = "/etc/ssl/consul.crt"
|
|
|
|
# key = "/etc/ssl/consul.key"
|
|
|
|
# insecureskipverify = true
|
|
|
|
|
2015-09-21 18:05:56 +02:00
|
|
|
|
2015-10-03 16:51:14 +02:00
|
|
|
################################################################
|
|
|
|
# Etcd configuration backend
|
|
|
|
################################################################
|
|
|
|
|
|
|
|
# Enable Etcd configuration backend
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# [etcd]
|
|
|
|
|
|
|
|
# Etcd server endpoint
|
|
|
|
#
|
|
|
|
# Required
|
|
|
|
#
|
|
|
|
# endpoint = "127.0.0.1:4001"
|
|
|
|
|
|
|
|
# Enable watch Etcd changes
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# watch = true
|
|
|
|
|
|
|
|
# Prefix used for KV store.
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# prefix = "/traefik"
|
|
|
|
|
|
|
|
# Override default configuration template. For advanced users :)
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# filename = "etcd.tmpl"
|
|
|
|
|
2016-02-19 17:10:48 +01:00
|
|
|
# Enable etcd TLS connection
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# [etcd.tls]
|
|
|
|
# ca = "/etc/ssl/ca.crt"
|
|
|
|
# cert = "/etc/ssl/etcd.crt"
|
|
|
|
# key = "/etc/ssl/etcd.key"
|
|
|
|
# insecureskipverify = true
|
|
|
|
|
2015-10-03 16:51:14 +02:00
|
|
|
|
|
|
|
################################################################
|
|
|
|
# Zookeeper configuration backend
|
|
|
|
################################################################
|
|
|
|
|
|
|
|
# Enable Zookeeperconfiguration backend
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# [zookeeper]
|
|
|
|
|
|
|
|
# Zookeeper server endpoint
|
|
|
|
#
|
|
|
|
# Required
|
|
|
|
#
|
|
|
|
# endpoint = "127.0.0.1:2181"
|
|
|
|
|
|
|
|
# Enable watch Zookeeper changes
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# watch = true
|
|
|
|
|
|
|
|
# Prefix used for KV store.
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# prefix = "/traefik"
|
|
|
|
|
|
|
|
# Override default configuration template. For advanced users :)
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# filename = "zookeeper.tmpl"
|
|
|
|
|
|
|
|
|
|
|
|
################################################################
|
|
|
|
# BoltDB configuration backend
|
|
|
|
################################################################
|
|
|
|
|
|
|
|
# Enable BoltDB configuration backend
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# [boltdb]
|
|
|
|
|
|
|
|
# BoltDB file
|
|
|
|
#
|
|
|
|
# Required
|
|
|
|
#
|
|
|
|
# endpoint = "/my.db"
|
|
|
|
|
|
|
|
# Enable watch BoltDB changes
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# watch = true
|
|
|
|
|
|
|
|
# Prefix used for KV store.
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# prefix = "/traefik"
|
|
|
|
|
|
|
|
# Override default configuration template. For advanced users :)
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
#
|
|
|
|
# filename = "boltdb.tmpl"
|
|
|
|
|
|
|
|
|
|
|
|
|
2015-09-14 15:38:58 +02:00
|
|
|
|
|
|
|
################################################################
|
|
|
|
# Sample rules
|
|
|
|
################################################################
|
|
|
|
# [backends]
|
|
|
|
# [backends.backend1]
|
2015-09-25 11:44:19 +02:00
|
|
|
# [backends.backend1.circuitbreaker]
|
|
|
|
# expression = "NetworkErrorRatio() > 0.5"
|
2015-09-14 15:38:58 +02:00
|
|
|
# [backends.backend1.servers.server1]
|
|
|
|
# url = "http://172.17.0.2:80"
|
|
|
|
# weight = 10
|
|
|
|
# [backends.backend1.servers.server2]
|
|
|
|
# url = "http://172.17.0.3:80"
|
|
|
|
# weight = 1
|
|
|
|
# [backends.backend2]
|
2015-09-25 11:44:19 +02:00
|
|
|
# [backends.backend2.LoadBalancer]
|
|
|
|
# method = "drr"
|
2015-09-14 15:38:58 +02:00
|
|
|
# [backends.backend2.servers.server1]
|
|
|
|
# url = "http://172.17.0.4:80"
|
|
|
|
# weight = 1
|
|
|
|
# [backends.backend2.servers.server2]
|
|
|
|
# url = "http://172.17.0.5:80"
|
|
|
|
# weight = 2
|
|
|
|
#
|
2015-09-15 16:09:21 +02:00
|
|
|
# [frontends]
|
|
|
|
# [frontends.frontend1]
|
2015-09-14 15:38:58 +02:00
|
|
|
# backend = "backend2"
|
2015-09-15 16:09:21 +02:00
|
|
|
# [frontends.frontend1.routes.test_1]
|
2015-09-15 18:35:32 +02:00
|
|
|
# rule = "Host"
|
2015-09-14 15:38:58 +02:00
|
|
|
# value = "test.localhost"
|
2015-09-15 16:09:21 +02:00
|
|
|
# [frontends.frontend2]
|
2015-09-14 15:38:58 +02:00
|
|
|
# backend = "backend1"
|
2015-10-30 11:33:41 +01:00
|
|
|
# passHostHeader = true
|
2016-02-01 16:09:13 +01:00
|
|
|
# entrypoints = ["https"] # overrides defaultEntryPoints
|
|
|
|
# [frontends.frontend2.routes.test_1]
|
|
|
|
# rule = "Host"
|
|
|
|
# value = "{subdomain:[a-z]+}.localhost"
|
|
|
|
# [frontends.frontend3]
|
|
|
|
# entrypoints = ["http", "https"] # overrides defaultEntryPoints
|
|
|
|
# backend = "backend2"
|
2015-09-15 18:35:32 +02:00
|
|
|
# rule = "Path"
|
2015-09-14 15:38:58 +02:00
|
|
|
# value = "/test"
|