2016-03-22 17:25:57 +01:00
# Global configuration
## Main section
```toml
# traefik.toml
################################################################
# Global configuration
################################################################
2016-10-27 16:17:02 +02:00
# Timeout in seconds.
# Duration to give active requests a chance to finish during hot-reloads
#
# Optional
# Default: 10
#
# graceTimeOut = 10
# Enable debug mode
#
# Optional
# Default: false
#
# debug = true
# Periodically check if a new version has been released
#
# Optional
# Default: true
#
# checkNewVersion = false
2016-03-22 17:25:57 +01:00
# Traefik logs file
# If not defined, logs to stdout
#
# Optional
#
# traefikLogsFile = "log/traefik.log"
# Access logs file
#
# Optional
#
# accessLogsFile = "log/access.log"
# Log level
#
# Optional
# Default: "ERROR"
2016-09-14 12:03:20 -07:00
# Accepted values, in order of severity: "DEBUG", "INFO", "WARN", "ERROR", "FATAL", "PANIC"
# Messages at and above the selected level will be logged.
2016-03-22 17:25:57 +01:00
#
# logLevel = "ERROR"
2016-10-21 16:02:18 +02:00
# Backends throttle duration: minimum duration in seconds between 2 events from providers
2016-03-22 17:25:57 +01:00
# before applying a new configuration. It avoids unnecessary reloads if multiples events
# are sent in a short amount of time.
#
# Optional
2016-10-21 16:02:18 +02:00
# Default: "2"
2016-03-22 17:25:57 +01:00
#
2016-10-21 16:02:18 +02:00
# ProvidersThrottleDuration = "5"
2016-03-22 17:25:57 +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
2016-07-31 17:08:33 +01:00
# If set to true invalid SSL certificates are accepted for backends.
# Note: This disables detection of man-in-the-middle attacks so should only be used on secure backend networks.
# Optional
# Default: false
#
# InsecureSkipVerify = true
2016-03-22 17:25:57 +01:00
# 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"]
```
2016-06-21 01:00:52 +02:00
### Constraints
In a micro-service architecture, with a central service discovery, setting constraints limits Træfɪ k scope to a smaller number of routes.
Træfɪ k filters services according to service attributes/tags set in your configuration backends.
Supported backends:
- Docker
- Consul K/V
- BoltDB
- Zookeeper
- Etcd
- Consul Catalog
Supported filters:
- ```tag` ``
```
# Constraints definition
#
# Optional
#
# Simple matching constraint
# constraints = ["tag==api"]
2016-09-20 16:56:29 +02:00
#
2016-06-21 01:00:52 +02:00
# Simple mismatching constraint
# constraints = ["tag!=api"]
2016-09-20 16:56:29 +02:00
#
2016-06-21 01:00:52 +02:00
# Globbing
# constraints = ["tag==us-*"]
2016-09-20 16:56:29 +02:00
#
2016-06-21 01:00:52 +02:00
# Backend-specific constraint
# [consulCatalog]
# endpoint = 127.0.0.1:8500
# constraints = ["tag==api"]
2016-09-20 16:56:29 +02:00
#
2016-06-21 01:00:52 +02:00
# Multiple constraints
# - "tag==" must match with at least one tag
# - "tag!=" must match with none of tags
# constraints = ["tag!=us-*", "tag!=asia-*"]
# [consulCatalog]
# endpoint = 127.0.0.1:8500
# constraints = ["tag==api", "tag!=v*-beta"]
```
2016-03-22 17:25:57 +01:00
## Entrypoints definition
```toml
# 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"
2016-06-15 22:38:40 +02:00
#
# Only accept clients that present a certificate signed by a specified
# Certificate Authority (CA)
# ClientCAFiles can be configured with multiple CA:s in the same file or
# use multiple files containing one or several CA:s. The CA:s has to be in PEM format.
# All clients will be required to present a valid cert.
# The requirement will apply to all server certs in the entrypoint
# In the example below both snitest.com and snitest.org will require client certs
#
# [entryPoints]
# [entryPoints.https]
# address = ":443"
# [entryPoints.https.tls]
# ClientCAFiles = ["tests/clientca1.crt", "tests/clientca2.crt"]
# [[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"
#
2016-07-21 17:05:58 +02:00
# To enable basic auth on an entrypoint
# with 2 user/pass: test:test and test2:test2
# Passwords can be encoded in MD5, SHA1 and BCrypt: you can use htpasswd to generate those ones
# [entryPoints]
# [entryPoints.http]
# address = ":80"
# [entryPoints.http.auth.basic]
# users = ["test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/", "test2:$apr1$d9hr9HBB$4HxwgUir3HP4EsggP/QNo0"]
#
# To enable digest auth on an entrypoint
# with 2 user/realm/pass: test:traefik:test and test2:traefik:test2
# You can use htdigest to generate those ones
# [entryPoints]
# [entryPoints.http]
# address = ":80"
# [entryPoints.http.auth.basic]
# users = ["test:traefik:a2688e031edb4be6a3797f3882655c05 ", "test2:traefik:518845800f9e2bfb1f1f740ec24f074e"]
2016-09-20 00:06:06 -06:00
#
# To specify an https entrypoint with a minimum TLS version, and specifying an array of cipher suites (from crypto/tls):
# [entryPoints]
# [entryPoints.https]
# address = ":443"
# [entryPoints.https.tls]
# MinVersion = "VersionTLS12"
# CipherSuites = ["TLS_RSA_WITH_AES_256_GCM_SHA384"]
# [[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"
2016-04-15 16:27:40 +02:00
2016-09-28 22:36:06 +01:00
# To enable compression support using gzip format:
# [entryPoints]
# [entryPoints.http]
# address = ":80"
# compress = true
2016-04-19 10:00:33 +02:00
[entryPoints]
2016-04-15 16:27:40 +02:00
[entryPoints.http]
address = ":80"
2016-03-22 17:25:57 +01:00
```
## Retry configuration
```toml
# Enable retry sending request if network error
#
# Optional
#
2016-04-15 16:27:40 +02:00
[retry]
2016-03-22 17:25:57 +01:00
# Number of attempts
#
# Optional
# Default: (number servers in backend) -1
#
# attempts = 3
```
## ACME (Let's Encrypt) configuration
```toml
2016-04-18 12:31:45 -04:00
# Sample entrypoint configuration when using ACME
[entryPoints]
[entryPoints.https]
address = ":443"
[entryPoints.https.tls]
2016-03-22 17:25:57 +01:00
# Enable ACME (Let's Encrypt): automatic SSL
#
# Optional
#
2016-04-15 16:27:40 +02:00
[acme]
2016-03-22 17:25:57 +01:00
# Email address used for registration
#
# Required
#
2016-04-15 16:27:40 +02:00
email = "test@traefik .io"
2016-03-22 17:25:57 +01:00
2016-09-29 13:49:12 +02:00
# File or key used for certificates storage.
2016-06-08 13:07:31 +02:00
# WARNING, if you use Traefik in Docker, you have 2 options:
2016-08-22 11:03:34 +02:00
# - create a file on your host and mount it as a volume
2016-06-08 13:07:31 +02:00
# storageFile = "acme.json"
# $ docker run -v "/my/host/acme.json:acme.json" traefik
2016-08-22 11:03:34 +02:00
# - mount the folder containing the file as a volume
2016-06-08 13:07:31 +02:00
# storageFile = "/etc/traefik/acme/acme.json"
# $ docker run -v "/my/host/acme:/etc/traefik/acme" traefik
2016-03-22 17:25:57 +01:00
#
# Required
#
2016-09-29 13:49:12 +02:00
storage = "acme.json" # or "traefik/acme/account" if using KV store
2016-03-22 17:25:57 +01:00
# Entrypoint to proxy acme challenge to.
2016-04-13 01:11:36 -07:00
# WARNING, must point to an entrypoint on port 443
2016-03-22 17:25:57 +01:00
#
# Required
#
2016-04-15 16:27:40 +02:00
entryPoint = "https"
2016-03-22 17:25:57 +01:00
# Enable on demand certificate. This will request a certificate from Let's Encrypt during the first TLS handshake for a hostname that does not yet have a certificate.
# WARNING, TLS handshakes will be slow when requesting a hostname certificate for the first time, this can leads to DoS attacks.
2016-08-22 11:03:34 +02:00
# WARNING, Take note that Let's Encrypt have rate limiting: https://letsencrypt.org/docs/rate-limits
2016-03-22 17:25:57 +01:00
#
# Optional
#
# onDemand = true
2016-08-05 20:42:45 +02:00
# Enable certificate generation on frontends Host rules. This will request a certificate from Let's Encrypt for each frontend with a Host rule.
# For example, a rule Host:test1.traefik.io,test2.traefik.io will request a certificate with main domain test1.traefik.io and SAN test2.traefik.io.
#
# Optional
#
# OnHostRule = true
2016-03-22 17:25:57 +01:00
# CA server to use
# Uncomment the line to run on the staging let's encrypt server
# Leave comment to go to prod
#
# Optional
#
# caServer = "https://acme-staging.api.letsencrypt.org/directory"
# Domains list
# You can provide SANs (alternative domains) to each main domain
2016-04-18 12:31:45 -04:00
# All domains must have A/AAAA records pointing to Traefik
2016-08-22 11:03:34 +02:00
# WARNING, Take note that Let's Encrypt have rate limiting: https://letsencrypt.org/docs/rate-limits
2016-03-22 17:25:57 +01:00
# Each domain & SANs will lead to a certificate request.
#
# [[acme.domains]]
# main = "local1.com"
# sans = ["test1.local1.com", "test2.local1.com"]
# [[acme.domains]]
# main = "local2.com"
# sans = ["test1.local2.com", "test2x.local2.com"]
# [[acme.domains]]
# main = "local3.com"
# [[acme.domains]]
# main = "local4.com"
2016-04-15 16:27:40 +02:00
[[acme.domains]]
main = "local1.com"
sans = ["test1.local1.com", "test2.local1.com"]
[[acme.domains]]
main = "local3.com"
[[acme.domains]]
main = "local4.com"
2016-03-22 17:25:57 +01:00
```
# Configuration backends
## File backend
Like any other reverse proxy, Træfɪ k can be configured with a file. You have two choices:
2016-08-22 11:03:34 +02:00
- simply add your configuration at the end of the global configuration file `traefik.toml` :
2016-03-22 17:25:57 +01:00
```toml
# traefik.toml
logLevel = "DEBUG"
defaultEntryPoints = ["http", "https"]
[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"
[file]
# rules
[backends]
[backends.backend1]
[backends.backend1.circuitbreaker]
expression = "NetworkErrorRatio() > 0.5"
[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]
2016-04-13 01:11:36 -07:00
[backends.backend1.maxconn]
amount = 10
extractorfunc = "request.host"
2016-03-22 17:25:57 +01:00
[backends.backend2.LoadBalancer]
method = "drr"
[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
[frontends]
[frontends.frontend1]
backend = "backend2"
[frontends.frontend1.routes.test_1]
rule = "Host:test.localhost"
[frontends.frontend2]
backend = "backend1"
passHostHeader = true
2016-06-06 22:40:42 +02:00
priority = 10
2016-03-22 17:25:57 +01:00
entrypoints = ["https"] # overrides defaultEntryPoints
[frontends.frontend2.routes.test_1]
rule = "Host:{subdomain:[a-z]+}.localhost"
[frontends.frontend3]
entrypoints = ["http", "https"] # overrides defaultEntryPoints
backend = "backend2"
rule = "Path:/test"
```
2016-04-21 23:38:44 +01:00
- or put your rules in a separate file, for example `rules.toml` :
2016-03-22 17:25:57 +01:00
```toml
# traefik.toml
logLevel = "DEBUG"
[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"
[file]
filename = "rules.toml"
```
```toml
# rules.toml
[backends]
[backends.backend1]
[backends.backend1.circuitbreaker]
expression = "NetworkErrorRatio() > 0.5"
[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]
2016-04-13 01:11:36 -07:00
[backends.backend1.maxconn]
amount = 10
extractorfunc = "request.host"
2016-03-22 17:25:57 +01:00
[backends.backend2.LoadBalancer]
method = "drr"
[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
[frontends]
[frontends.frontend1]
backend = "backend2"
[frontends.frontend1.routes.test_1]
rule = "Host:test.localhost"
[frontends.frontend2]
backend = "backend1"
passHostHeader = true
2016-06-06 22:40:42 +02:00
priority = 10
2016-03-22 17:25:57 +01:00
entrypoints = ["https"] # overrides defaultEntryPoints
[frontends.frontend2.routes.test_1]
rule = "Host:{subdomain:[a-z]+}.localhost"
[frontends.frontend3]
entrypoints = ["http", "https"] # overrides defaultEntryPoints
backend = "backend2"
rule = "Path:/test"
```
If you want Træfɪ k to watch file changes automatically, just add:
```toml
[file]
watch = true
```
## API backend
2016-08-22 11:03:34 +02:00
Træfik can be configured using a RESTful api.
2016-03-22 17:25:57 +01:00
To enable it:
```toml
[web]
address = ":8080"
# SSL certificate and key used
#
# Optional
#
# CertFile = "traefik.crt"
# KeyFile = "traefik.key"
#
# Set REST API to read-only mode
#
# Optional
# ReadOnly = false
2016-09-15 15:24:22 +02:00
#
# To enable basic auth on the webui
# with 2 user/pass: test:test and test2:test2
# Passwords can be encoded in MD5, SHA1 and BCrypt: you can use htpasswd to generate those ones
2016-09-20 00:06:06 -06:00
# [web.auth.basic]
2016-09-15 15:24:22 +02:00
# users = ["test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/", "test2:$apr1$d9hr9HBB$4HxwgUir3HP4EsggP/QNo0"]
# To enable digest auth on the webui
# with 2 user/realm/pass: test:traefik:test and test2:traefik:test2
# You can use htdigest to generate those ones
2016-09-20 00:06:06 -06:00
# [web.auth.basic]
2016-09-15 15:24:22 +02:00
# users = ["test:traefik:a2688e031edb4be6a3797f3882655c05 ", "test2:traefik:518845800f9e2bfb1f1f740ec24f074e"]
2016-03-22 17:25:57 +01:00
```
- `/` : provides a simple HTML frontend of Træfik
![Web UI Providers ](img/web.frontend.png )
![Web UI Health ](img/traefik-health.png )
2016-08-19 12:02:26 -04:00
- `/ping` : `GET` simple endpoint to check for Træfik process liveness.
```sh
$ curl -sv "http://localhost:8080/ping"
* Trying ::1...
* Connected to localhost (::1) port 8080 (#0 )
> GET /ping HTTP/1.1
> Host: localhost:8080
> User-Agent: curl/7.43.0
> Accept: */*
>
< HTTP / 1 . 1 200 OK
< Date: Thu , 25 Aug 2016 01:35:36 GMT
< Content-Length: 2
< Content-Type: text / plain ; charset = utf-8
<
* Connection #0 to host localhost left intact
OK
```
2016-03-22 17:25:57 +01:00
- `/health` : `GET` json metrics
```sh
$ curl -s "http://localhost:8080/health" | jq .
{
// Træfɪ k PID
"pid": 2458,
// Træfɪ k server uptime (formated time)
"uptime": "39m6.885931127s",
// Træfɪ k server uptime in seconds
"uptime_sec": 2346.885931127,
// current server date
"time": "2015-10-07 18:32:24.362238909 +0200 CEST",
// current server date in seconds
"unixtime": 1444235544,
// count HTTP response status code in realtime
"status_code_count": {
"502": 1
},
// count HTTP response status code since Træfɪ k started
"total_status_code_count": {
"200": 7,
"404": 21,
"502": 13
},
// count HTTP response
"count": 1,
// count HTTP response
"total_count": 41,
// sum of all response time (formated time)
"total_response_time": "35.456865605s",
// sum of all response time in seconds
"total_response_time_sec": 35.456865605,
// average response time (formated time)
"average_response_time": "864.8016ms",
// average response time in seconds
"average_response_time_sec": 0.8648016000000001
}
```
- `/api` : `GET` configuration for all providers
```sh
$ curl -s "http://localhost:8080/api" | jq .
{
"file": {
"frontends": {
"frontend2": {
"routes": {
"test_2": {
"rule": "Path:/test"
}
},
"backend": "backend1"
},
"frontend1": {
"routes": {
"test_1": {
"rule": "Host:test.localhost"
}
},
"backend": "backend2"
}
},
"backends": {
"backend2": {
"loadBalancer": {
"method": "drr"
},
"servers": {
"server2": {
"weight": 2,
"URL": "http://172.17.0.5:80"
},
"server1": {
"weight": 1,
"url": "http://172.17.0.4:80"
}
}
},
"backend1": {
"loadBalancer": {
"method": "wrr"
},
"circuitBreaker": {
"expression": "NetworkErrorRatio() > 0.5"
},
"servers": {
"server2": {
"weight": 1,
"url": "http://172.17.0.3:80"
},
"server1": {
"weight": 10,
"url": "http://172.17.0.2:80"
}
}
}
}
}
}
```
- `/api/providers` : `GET` providers
- `/api/providers/{provider}` : `GET` or `PUT` provider
- `/api/providers/{provider}/backends` : `GET` backends
- `/api/providers/{provider}/backends/{backend}` : `GET` a backend
- `/api/providers/{provider}/backends/{backend}/servers` : `GET` servers in a backend
- `/api/providers/{provider}/backends/{backend}/servers/{server}` : `GET` a server in a backend
- `/api/providers/{provider}/frontends` : `GET` frontends
- `/api/providers/{provider}/frontends/{frontend}` : `GET` a frontend
- `/api/providers/{provider}/frontends/{frontend}/routes` : `GET` routes in a frontend
- `/api/providers/{provider}/frontends/{frontend}/routes/{route}` : `GET` a route in a frontend
## Docker backend
Træfɪ k can be configured to use Docker as a backend configuration:
```toml
################################################################
# 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"
# Enable watch docker changes
#
# Optional
#
watch = true
# Override default configuration template. For advanced users :)
#
# Optional
#
# filename = "docker.tmpl"
2016-07-14 11:32:15 +02:00
# Expose containers by default in traefik
#
# Optional
# Default: true
#
exposedbydefault = true
2016-09-20 14:52:35 +02:00
# Use the IP address from the binded port instead of the inner network one. For specific use-case :)
2016-08-05 11:02:46 -03:00
2016-09-20 14:52:35 +02:00
#
# Optional
# Default: false
#
usebindportip = true
2016-08-05 11:02:46 -03:00
# Use Swarm Mode services as data provider
#
# Optional
# Default: false
#
swarmmode = false
2016-09-20 14:52:35 +02:00
2016-03-22 17:25:57 +01:00
# Enable docker TLS connection
#
# [docker.tls]
# ca = "/etc/ssl/ca.crt"
# cert = "/etc/ssl/docker.crt"
# key = "/etc/ssl/docker.key"
# insecureskipverify = true
```
Labels can be used on containers to override default behaviour:
- `traefik.backend=foo` : assign the container to `foo` backend
2016-08-25 00:22:06 -04:00
- `traefik.backend.maxconn.amount=10` : set a maximum number of connections to the backend. Must be used in conjunction with the below label to take effect.
- `traefik.backend.maxconn.extractorfunc=client.ip` : set the function to be used against the request to determine what to limit maximum connections to the backend by. Must be used in conjunction with the above label to take effect.
- `traefik.backend.loadbalancer.method=drr` : override the default `wrr` load balancer algorithm
2016-09-28 16:29:19 +02:00
- `traefik.backend.loadbalancer.sticky=true` : enable backend sticky sessions
2016-08-25 00:22:06 -04:00
- `traefik.backend.circuitbreaker.expression=NetworkErrorRatio() > 0.5` : create a [circuit breaker ](/basics/#backends ) to be used against the backend
2016-03-22 17:25:57 +01:00
- `traefik.port=80` : register this port. Useful when the container exposes multiples ports.
- `traefik.protocol=https` : override the default `http` protocol
- `traefik.weight=10` : assign this weight to the container
- `traefik.enable=false` : disable this container in Træfɪ k
2016-04-13 21:12:49 +02:00
- `traefik.frontend.rule=Host:test.traefik.io` : override the default frontend rule (Default: `Host:{containerName}.{domain}` ).
2016-03-22 17:25:57 +01:00
- `traefik.frontend.passHostHeader=true` : forward client `Host` header to the backend.
2016-06-06 22:40:42 +02:00
- `traefik.frontend.priority=10` : override default frontend priority
2016-03-22 17:25:57 +01:00
- `traefik.frontend.entryPoints=http,https` : assign this frontend to entry points `http` and `https` . Overrides `defaultEntryPoints` .
2016-05-31 22:11:17 -07:00
- `traefik.docker.network` : Set the docker network to use for connections to this container
2016-03-22 17:25:57 +01:00
2016-08-22 11:03:34 +02:00
NB: when running inside a container, Træfɪ k will need network access through `docker network connect <network> <traefik-container>`
2016-03-22 17:25:57 +01:00
## Marathon backend
Træfɪ k can be configured to use Marathon as a backend configuration:
```toml
################################################################
# 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.
#
# Required
#
domain = "marathon.localhost"
# Override default configuration template. For advanced users :)
#
# Optional
#
# filename = "marathon.tmpl"
# Expose Marathon apps by default in traefik
#
# Optional
# Default: false
#
2016-06-01 16:47:39 +02:00
# exposedByDefault = true
# Convert Marathon groups to subdomains
# Default behavior: /foo/bar/myapp => foo-bar-myapp.{defaultDomain}
# with groupsAsSubDomains enabled: /foo/bar/myapp => myapp.bar.foo.{defaultDomain}
#
# Optional
# Default: false
#
# groupsAsSubDomains = true
2016-03-22 17:25:57 +01:00
2016-10-06 17:42:19 +02:00
# Enable compatibility with marathon-lb labels
#
# Optional
# Default: false
#
# marathonLBCompatibility = true
2016-03-22 17:25:57 +01:00
# Enable Marathon basic authentication
#
# Optional
#
# [marathon.basic]
# httpBasicAuthUser = "foo"
# httpBasicPassword = "bar"
# TLS client configuration. https://golang.org/pkg/crypto/tls/#Config
#
# Optional
#
# [marathon.TLS]
# InsecureSkipVerify = true
2016-06-18 14:51:52 +02:00
# DCOSToken for DCOS environment, This will override the Authorization header
#
# Optional
#
# dcosToken = "xxxxxx"
2016-03-22 17:25:57 +01:00
```
Labels can be used on containers to override default behaviour:
- `traefik.backend=foo` : assign the application to `foo` backend
2016-08-13 12:55:15 -04:00
- `traefik.backend.maxconn.amount=10` : set a maximum number of connections to the backend. Must be used in conjunction with the below label to take effect.
- `traefik.backend.maxconn.extractorfunc=client.ip` : set the function to be used against the request to determine what to limit maximum connections to the backend by. Must be used in conjunction with the above label to take effect.
- `traefik.backend.loadbalancer.method=drr` : override the default `wrr` load balancer algorithm
2016-09-28 16:29:19 +02:00
- `traefik.backend.loadbalancer.sticky=true` : enable backend sticky sessions
2016-08-13 12:55:15 -04:00
- `traefik.backend.circuitbreaker.expression=NetworkErrorRatio() > 0.5` : create a [circuit breaker ](/basics/#backends ) to be used against the backend
2016-03-22 17:25:57 +01:00
- `traefik.portIndex=1` : register port by index in the application's ports array. Useful when the application exposes multiple ports.
- `traefik.port=80` : register the explicit application port value. Cannot be used alongside `traefik.portIndex` .
- `traefik.protocol=https` : override the default `http` protocol
- `traefik.weight=10` : assign this weight to the application
- `traefik.enable=false` : disable this application in Træfɪ k
2016-04-13 21:12:49 +02:00
- `traefik.frontend.rule=Host:test.traefik.io` : override the default frontend rule (Default: `Host:{containerName}.{domain}` ).
2016-03-22 17:25:57 +01:00
- `traefik.frontend.passHostHeader=true` : forward client `Host` header to the backend.
2016-06-06 22:40:42 +02:00
- `traefik.frontend.priority=10` : override default frontend priority
2016-03-22 17:25:57 +01:00
- `traefik.frontend.entryPoints=http,https` : assign this frontend to entry points `http` and `https` . Overrides `defaultEntryPoints` .
2016-04-20 13:43:37 +02:00
2016-09-30 15:37:52 +02:00
## Mesos generic backend
Træfɪ k can be configured to use Mesos as a backend configuration:
```toml
################################################################
# Mesos configuration backend
################################################################
# Enable Mesos configuration backend
#
# Optional
#
[mesos]
# Mesos server endpoint.
# You can also specify multiple endpoint for Mesos:
# endpoint = "192.168.35.40:5050,192.168.35.41:5050,192.168.35.42:5050"
# endpoint = "zk://192.168.35.20:2181,192.168.35.21:2181,192.168.35.22:2181/mesos"
#
# Required
#
endpoint = "http://127.0.0.1:8080"
# Enable watch Mesos changes
#
# Optional
#
watch = true
# Default domain used.
# Can be overridden by setting the "traefik.domain" label on an application.
#
# Required
#
domain = "mesos.localhost"
# Override default configuration template. For advanced users :)
#
# Optional
#
# filename = "mesos.tmpl"
# Expose Mesos apps by default in traefik
#
# Optional
# Default: false
#
# ExposedByDefault = true
# TLS client configuration. https://golang.org/pkg/crypto/tls/#Config
#
# Optional
#
# [mesos.TLS]
# InsecureSkipVerify = true
# Zookeeper timeout (in seconds)
#
# Optional
#
# ZkDetectionTimeout = 30
# Polling interval (in seconds)
#
# Optional
#
# RefreshSeconds = 30
# IP sources (e.g. host, docker, mesos, rkt)
#
# Optional
#
# IPSources = "host"
# HTTP Timeout (in seconds)
#
# Optional
#
# StateTimeoutSecond = "host"
```
2016-04-20 13:43:37 +02:00
## Kubernetes Ingress backend
Træfɪ k can be configured to use Kubernetes Ingress as a backend configuration:
```toml
################################################################
# Kubernetes Ingress configuration backend
################################################################
# Enable Kubernetes Ingress configuration backend
#
# Optional
#
[kubernetes]
# Kubernetes server endpoint
#
# When deployed as a replication controller in Kubernetes,
# Traefik will use env variable KUBERNETES_SERVICE_HOST
# and KUBERNETES_SERVICE_PORT_HTTPS as endpoint
# Secure token will be found in /var/run/secrets/kubernetes.io/serviceaccount/token
# and SSL CA cert in /var/run/secrets/kubernetes.io/serviceaccount/ca.crt
2016-05-31 22:11:17 -07:00
#
2016-04-20 13:43:37 +02:00
# Optional
#
# endpoint = "http://localhost:8080"
2016-04-28 01:23:55 +01:00
# namespaces = ["default","production"]
2016-07-12 01:25:01 -04:00
#
# See: http://kubernetes.io/docs/user-guide/labels/#list-and-watch-filtering
# labelselector = "A and not B"
#
2016-04-20 13:43:37 +02:00
```
2016-05-17 13:50:06 +03:00
Annotations can be used on containers to override default behaviour for the whole Ingress resource:
2016-05-19 01:09:32 +03:00
- `traefik.frontend.rule.type: PathPrefixStrip` : override the default frontend rule type (Default: `PathPrefix` ).
2016-05-17 13:50:06 +03:00
2016-10-17 18:36:32 +02:00
You can find here an example [ingress ](https://raw.githubusercontent.com/containous/traefik/master/examples/k8s/cheese-ingress.yaml ) and [replication controller ](https://raw.githubusercontent.com/containous/traefik/master/examples/k8s/traefik.yaml ).
2016-04-20 13:43:37 +02:00
2016-03-22 17:25:57 +01:00
## Consul backend
Træfɪ k can be configured to use Consul as a backend configuration:
```toml
################################################################
# Consul KV configuration backend
################################################################
# Enable Consul KV configuration backend
#
# Optional
#
[consul]
# Consul server endpoint
#
# Required
#
endpoint = "127.0.0.1:8500"
# Enable watch Consul changes
#
# Optional
#
watch = true
# Prefix used for KV store.
#
# Optional
#
prefix = "traefik"
# Override default configuration template. For advanced users :)
#
# Optional
#
# filename = "consul.tmpl"
# Enable consul TLS connection
#
# Optional
#
# [consul.tls]
# ca = "/etc/ssl/ca.crt"
# cert = "/etc/ssl/consul.crt"
# key = "/etc/ssl/consul.key"
# insecureskipverify = true
```
2016-07-11 17:32:28 +02:00
Please refer to the [Key Value storage structure ](/user-guide/kv-config/#key-value-storage-structure ) section to get documentation on traefik KV structure.
2016-03-22 17:25:57 +01:00
## Consul catalog backend
Træfɪ k can be configured to use service discovery catalog of Consul as a backend configuration:
```toml
################################################################
# Consul Catalog configuration backend
################################################################
# Enable Consul Catalog configuration backend
#
# Optional
#
[consulCatalog]
# Consul server endpoint
#
# Required
#
endpoint = "127.0.0.1:8500"
# Default domain used.
#
# Optional
#
domain = "consul.localhost"
2016-04-12 09:49:37 +02:00
# Prefix for Consul catalog tags
#
# Optional
#
prefix = "traefik"
2016-03-22 17:25:57 +01:00
```
This backend will create routes matching on hostname based on the service name
used in consul.
2016-04-12 09:49:37 +02:00
Additional settings can be defined using Consul Catalog tags:
2016-04-13 21:12:49 +02:00
2016-06-06 22:40:42 +02:00
- `traefik.enable=false` : disable this container in Træfɪ k
- `traefik.protocol=https` : override the default `http` protocol
- `traefik.backend.weight=10` : assign this weight to the container
- `traefik.backend.circuitbreaker=NetworkErrorRatio() > 0.5`
- `traefik.backend.loadbalancer=drr` : override the default load balancing mode
2016-08-24 23:46:47 -04:00
- `traefik.backend.maxconn.amount=10` : set a maximum number of connections to the backend. Must be used in conjunction with the below label to take effect.
- `traefik.backend.maxconn.extractorfunc=client.ip` : set the function to be used against the request to determine what to limit maximum connections to the backend by. Must be used in conjunction with the above label to take effect.
2016-06-06 22:40:42 +02:00
- `traefik.frontend.rule=Host:test.traefik.io` : override the default frontend rule (Default: `Host:{containerName}.{domain}` ).
- `traefik.frontend.passHostHeader=true` : forward client `Host` header to the backend.
- `traefik.frontend.priority=10` : override default frontend priority
- `traefik.frontend.entryPoints=http,https` : assign this frontend to entry points `http` and `https` . Overrides `defaultEntryPoints` .
2016-03-22 17:25:57 +01:00
## Etcd backend
Træfɪ k can be configured to use Etcd as a backend configuration:
```toml
################################################################
# Etcd configuration backend
################################################################
# Enable Etcd configuration backend
#
# Optional
#
2016-04-15 16:27:40 +02:00
[etcd]
2016-03-22 17:25:57 +01:00
# Etcd server endpoint
#
# Required
#
2016-07-11 12:36:35 +01:00
endpoint = "127.0.0.1:2379"
2016-03-22 17:25:57 +01:00
# Enable watch Etcd changes
#
# Optional
#
2016-04-15 16:27:40 +02:00
watch = true
2016-03-22 17:25:57 +01:00
# Prefix used for KV store.
#
# Optional
#
2016-04-15 16:27:40 +02:00
prefix = "/traefik"
2016-03-22 17:25:57 +01:00
# Override default configuration template. For advanced users :)
#
# Optional
#
# filename = "etcd.tmpl"
# Enable etcd TLS connection
#
# Optional
#
# [etcd.tls]
# ca = "/etc/ssl/ca.crt"
# cert = "/etc/ssl/etcd.crt"
# key = "/etc/ssl/etcd.key"
# insecureskipverify = true
```
2016-07-11 17:32:28 +02:00
Please refer to the [Key Value storage structure ](/user-guide/kv-config/#key-value-storage-structure ) section to get documentation on traefik KV structure.
2016-03-22 17:25:57 +01:00
## Zookeeper backend
Træfɪ k can be configured to use Zookeeper as a backend configuration:
```toml
################################################################
# Zookeeper configuration backend
################################################################
# Enable Zookeeperconfiguration backend
#
# Optional
#
2016-04-15 16:27:40 +02:00
[zookeeper]
2016-03-22 17:25:57 +01:00
# Zookeeper server endpoint
#
# Required
#
2016-04-15 16:27:40 +02:00
endpoint = "127.0.0.1:2181"
2016-03-22 17:25:57 +01:00
# Enable watch Zookeeper changes
#
# Optional
#
2016-04-15 16:27:40 +02:00
watch = true
2016-03-22 17:25:57 +01:00
# Prefix used for KV store.
#
# Optional
#
2016-04-15 16:27:40 +02:00
prefix = "/traefik"
2016-03-22 17:25:57 +01:00
# Override default configuration template. For advanced users :)
#
# Optional
#
# filename = "zookeeper.tmpl"
```
2016-07-11 17:32:28 +02:00
Please refer to the [Key Value storage structure ](/user-guide/kv-config/#key-value-storage-structure ) section to get documentation on traefik KV structure.
2016-03-22 17:25:57 +01:00
## BoltDB backend
Træfɪ k can be configured to use BoltDB as a backend configuration:
```toml
################################################################
# BoltDB configuration backend
################################################################
# Enable BoltDB configuration backend
#
# Optional
#
2016-04-15 16:27:40 +02:00
[boltdb]
2016-03-22 17:25:57 +01:00
# BoltDB file
#
# Required
#
2016-04-15 16:27:40 +02:00
endpoint = "/my.db"
2016-03-22 17:25:57 +01:00
# Enable watch BoltDB changes
#
# Optional
#
2016-04-15 16:27:40 +02:00
watch = true
2016-03-22 17:25:57 +01:00
# Prefix used for KV store.
#
# Optional
#
2016-04-15 16:27:40 +02:00
prefix = "/traefik"
2016-03-22 17:25:57 +01:00
# Override default configuration template. For advanced users :)
#
# Optional
#
# filename = "boltdb.tmpl"
```
2016-07-11 17:32:28 +02:00
Please refer to the [Key Value storage structure ](/user-guide/kv-config/#key-value-storage-structure ) section to get documentation on traefik KV structure.