Fix documentation
Signed-off-by: Emile Vauge <emile@vauge.com>
This commit is contained in:
parent
bb072a1f8f
commit
d5e1d2efd5
5 changed files with 117 additions and 207 deletions
305
docs/index.md
305
docs/index.md
|
@ -2,25 +2,25 @@
|
||||||
<img src="http://traefik.github.io/traefik.logo.svg" alt="Træfɪk" title="Træfɪk" />
|
<img src="http://traefik.github.io/traefik.logo.svg" alt="Træfɪk" title="Træfɪk" />
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
# <a id="top"></a> Documentation
|
# Documentation
|
||||||
|
|
||||||
- [Basics](#basics)
|
- [Basics](#basics)
|
||||||
- [Launch configuration](#launch)
|
- [Launch configuration](#launch-configuration)
|
||||||
- [Global configuration](#global)
|
- [Global configuration](#global-configuration)
|
||||||
- [File backend](#file)
|
- [File backend](#file-backend)
|
||||||
- [API backend](#api)
|
- [API backend](#api-backend)
|
||||||
- [Docker backend](#docker)
|
- [Docker backend](#docker-backend)
|
||||||
- [Mesos/Marathon backend](#marathon)
|
- [Mesos/Marathon backend](#marathon-backend)
|
||||||
- [Consul backend](#consul)
|
- [Consul backend](#consul-backend)
|
||||||
- [Consul catalog backend](#consulcatalog)
|
- [Consul catalog backend](#consul-catalog-backend)
|
||||||
- [Etcd backend](#etcd)
|
- [Etcd backend](#etcd-backend)
|
||||||
- [Zookeeper backend](#zk)
|
- [Zookeeper backend](#zookeeper-backend)
|
||||||
- [Boltdb backend](#boltdb)
|
- [Boltdb backend](#boltdb-backend)
|
||||||
- [Atomic configuration changes](#atomicconfig)
|
- [Atomic configuration changes](#atomic-configuration-changes)
|
||||||
- [Benchmarks](#benchmarks)
|
- [Benchmarks](#benchmarks)
|
||||||
|
|
||||||
|
|
||||||
## <a id="basics"></a> Basics
|
## Basics
|
||||||
|
|
||||||
|
|
||||||
Træfɪk is a modern HTTP reverse proxy and load balancer made to deploy microservices with ease.
|
Træfɪk is a modern HTTP reverse proxy and load balancer made to deploy microservices with ease.
|
||||||
|
@ -28,12 +28,12 @@ It supports several backends ([Docker :whale:](https://www.docker.com/), [Mesos/
|
||||||
|
|
||||||
Basically, Træfɪk is a http router, which sends traffic from frontends to http backends, following rules you have configured.
|
Basically, Træfɪk is a http router, which sends traffic from frontends to http backends, following rules you have configured.
|
||||||
|
|
||||||
### <a id="frontends"></a> Frontends
|
### Frontends
|
||||||
|
|
||||||
Frontends can be defined using the following rules:
|
Frontends can be defined using the following rules:
|
||||||
|
|
||||||
- `Headers`: Headers adds a matcher for request header values. It accepts a sequence of key/value pairs to be matched. For example: `application/json`
|
- `Headers`: Headers adds a matcher for request header values. It accepts a sequence of key/value pairs to be matched. For example: `Content-Type, application/json`
|
||||||
- `HeadersRegexp`: Regular expressions can be used with headers as well. It accepts a sequence of key/value pairs, where the value has regex support. For example: `application/(text|json)`
|
- `HeadersRegexp`: Regular expressions can be used with headers as well. It accepts a sequence of key/value pairs, where the value has regex support. For example: `Content-Type, application/(text|json)`
|
||||||
- `Host`: Host adds a matcher for the URL host. It accepts a template with zero or more URL variables enclosed by `{}`. Variables can define an optional regexp pattern to be matched: `www.traefik.io`, `{subdomain:[a-z]+}.traefik.io`
|
- `Host`: Host adds a matcher for the URL host. It accepts a template with zero or more URL variables enclosed by `{}`. Variables can define an optional regexp pattern to be matched: `www.traefik.io`, `{subdomain:[a-z]+}.traefik.io`
|
||||||
- `Methods`: Methods adds a matcher for HTTP methods. It accepts a sequence of one or more methods to be matched, e.g.: `GET`, `POST`, `PUT`
|
- `Methods`: Methods adds a matcher for HTTP methods. It accepts a sequence of one or more methods to be matched, e.g.: `GET`, `POST`, `PUT`
|
||||||
- `Path`: Path adds a matcher for the URL path. It accepts a template with zero or more URL variables enclosed by `{}`. The template must start with a `/`. For exemple `/products/` `/articles/{category}/{id:[0-9]+}`
|
- `Path`: Path adds a matcher for the URL path. It accepts a template with zero or more URL variables enclosed by `{}`. The template must start with a `/`. For exemple `/products/` `/articles/{category}/{id:[0-9]+}`
|
||||||
|
@ -70,7 +70,7 @@ For example:
|
||||||
- `ResponseCodeRatio(500, 600, 0, 600) > 0.5`: ratio of response codes in range [500-600) to [0-600)
|
- `ResponseCodeRatio(500, 600, 0, 600) > 0.5`: ratio of response codes in range [500-600) to [0-600)
|
||||||
|
|
||||||
|
|
||||||
## <a id="launch"></a> Launch configuration
|
## Launch configuration
|
||||||
|
|
||||||
Træfɪk can be configured using a TOML file configuration, arguments, or both.
|
Træfɪk can be configured using a TOML file configuration, arguments, or both.
|
||||||
By default, Træfɪk will try to find a `traefik.toml` in the following places:
|
By default, Træfɪk will try to find a `traefik.toml` in the following places:
|
||||||
|
@ -176,7 +176,7 @@ Flags:
|
||||||
Use "traefik [command] --help" for more information about a command.
|
Use "traefik [command] --help" for more information about a command.
|
||||||
```
|
```
|
||||||
|
|
||||||
## <a id="global"></a> Global configuration
|
## Global configuration
|
||||||
|
|
||||||
```toml
|
```toml
|
||||||
# traefik.toml
|
# traefik.toml
|
||||||
|
@ -432,24 +432,21 @@ entryPoint = "https"
|
||||||
[frontends.frontend1]
|
[frontends.frontend1]
|
||||||
backend = "backend2"
|
backend = "backend2"
|
||||||
[frontends.frontend1.routes.test_1]
|
[frontends.frontend1.routes.test_1]
|
||||||
rule = "Host"
|
rule = "Host:test.localhost"
|
||||||
value = "test.localhost"
|
|
||||||
[frontends.frontend2]
|
[frontends.frontend2]
|
||||||
backend = "backend1"
|
backend = "backend1"
|
||||||
passHostHeader = true
|
passHostHeader = true
|
||||||
entrypoints = ["https"] # overrides defaultEntryPoints
|
entrypoints = ["https"] # overrides defaultEntryPoints
|
||||||
[frontends.frontend2.routes.test_1]
|
[frontends.frontend2.routes.test_1]
|
||||||
rule = "Host"
|
rule = "Host:{subdomain:[a-z]+}.localhost"
|
||||||
value = "{subdomain:[a-z]+}.localhost"
|
|
||||||
[frontends.frontend3]
|
[frontends.frontend3]
|
||||||
entrypoints = ["http", "https"] # overrides defaultEntryPoints
|
entrypoints = ["http", "https"] # overrides defaultEntryPoints
|
||||||
backend = "backend2"
|
backend = "backend2"
|
||||||
rule = "Path"
|
rule = "Path:/test"
|
||||||
value = "/test"
|
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
## <a id="file"></a> File backend
|
## File backend
|
||||||
|
|
||||||
Like any other reverse proxy, Træfɪk can be configured with a file. You have two choices:
|
Like any other reverse proxy, Træfɪk can be configured with a file. You have two choices:
|
||||||
|
|
||||||
|
@ -502,20 +499,17 @@ logLevel = "DEBUG"
|
||||||
[frontends.frontend1]
|
[frontends.frontend1]
|
||||||
backend = "backend2"
|
backend = "backend2"
|
||||||
[frontends.frontend1.routes.test_1]
|
[frontends.frontend1.routes.test_1]
|
||||||
rule = "Host"
|
rule = "Host:test.localhost"
|
||||||
value = "test.localhost"
|
|
||||||
[frontends.frontend2]
|
[frontends.frontend2]
|
||||||
backend = "backend1"
|
backend = "backend1"
|
||||||
passHostHeader = true
|
passHostHeader = true
|
||||||
entrypoints = ["https"] # overrides defaultEntryPoints
|
entrypoints = ["https"] # overrides defaultEntryPoints
|
||||||
[frontends.frontend2.routes.test_1]
|
[frontends.frontend2.routes.test_1]
|
||||||
rule = "Host"
|
rule = "Host:{subdomain:[a-z]+}.localhost"
|
||||||
value = "{subdomain:[a-z]+}.localhost"
|
|
||||||
[frontends.frontend3]
|
[frontends.frontend3]
|
||||||
entrypoints = ["http", "https"] # overrides defaultEntryPoints
|
entrypoints = ["http", "https"] # overrides defaultEntryPoints
|
||||||
backend = "backend2"
|
backend = "backend2"
|
||||||
rule = "Path"
|
rule = "Path:/test"
|
||||||
value = "/test"
|
|
||||||
```
|
```
|
||||||
|
|
||||||
- or put your rules in a separate file, for example `rules.tml`:
|
- or put your rules in a separate file, for example `rules.tml`:
|
||||||
|
@ -569,20 +563,17 @@ filename = "rules.toml"
|
||||||
[frontends.frontend1]
|
[frontends.frontend1]
|
||||||
backend = "backend2"
|
backend = "backend2"
|
||||||
[frontends.frontend1.routes.test_1]
|
[frontends.frontend1.routes.test_1]
|
||||||
rule = "Host"
|
rule = "Host:test.localhost"
|
||||||
value = "test.localhost"
|
|
||||||
[frontends.frontend2]
|
[frontends.frontend2]
|
||||||
backend = "backend1"
|
backend = "backend1"
|
||||||
passHostHeader = true
|
passHostHeader = true
|
||||||
entrypoints = ["https"] # overrides defaultEntryPoints
|
entrypoints = ["https"] # overrides defaultEntryPoints
|
||||||
[frontends.frontend2.routes.test_1]
|
[frontends.frontend2.routes.test_1]
|
||||||
rule = "Host"
|
rule = "Host:{subdomain:[a-z]+}.localhost"
|
||||||
value = "{subdomain:[a-z]+}.localhost"
|
|
||||||
[frontends.frontend3]
|
[frontends.frontend3]
|
||||||
entrypoints = ["http", "https"] # overrides defaultEntryPoints
|
entrypoints = ["http", "https"] # overrides defaultEntryPoints
|
||||||
backend = "backend2"
|
backend = "backend2"
|
||||||
rule = "Path"
|
rule = "Path:/test"
|
||||||
value = "/test"
|
|
||||||
```
|
```
|
||||||
|
|
||||||
If you want Træfɪk to watch file changes automatically, just add:
|
If you want Træfɪk to watch file changes automatically, just add:
|
||||||
|
@ -592,7 +583,7 @@ If you want Træfɪk to watch file changes automatically, just add:
|
||||||
watch = true
|
watch = true
|
||||||
```
|
```
|
||||||
|
|
||||||
## <a id="api"></a> API backend
|
## API backend
|
||||||
|
|
||||||
Træfik can be configured using a restful api.
|
Træfik can be configured using a restful api.
|
||||||
To enable it:
|
To enable it:
|
||||||
|
@ -669,8 +660,7 @@ $ curl -s "http://localhost:8080/api" | jq .
|
||||||
"frontend2": {
|
"frontend2": {
|
||||||
"routes": {
|
"routes": {
|
||||||
"test_2": {
|
"test_2": {
|
||||||
"value": "/test",
|
"rule": "Path:/test"
|
||||||
"rule": "Path"
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"backend": "backend1"
|
"backend": "backend1"
|
||||||
|
@ -678,8 +668,7 @@ $ curl -s "http://localhost:8080/api" | jq .
|
||||||
"frontend1": {
|
"frontend1": {
|
||||||
"routes": {
|
"routes": {
|
||||||
"test_1": {
|
"test_1": {
|
||||||
"value": "test.localhost",
|
"rule": "Host:test.localhost"
|
||||||
"rule": "Host"
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"backend": "backend2"
|
"backend": "backend2"
|
||||||
|
@ -736,7 +725,7 @@ $ curl -s "http://localhost:8080/api" | jq .
|
||||||
- `/api/providers/{provider}/frontends/{frontend}/routes/{route}`: `GET` a route in a frontend
|
- `/api/providers/{provider}/frontends/{frontend}/routes/{route}`: `GET` a route in a frontend
|
||||||
|
|
||||||
|
|
||||||
## <a id="docker"></a> Docker backend
|
## Docker backend
|
||||||
|
|
||||||
Træfɪk can be configured to use Docker as a backend configuration:
|
Træfɪk can be configured to use Docker as a backend configuration:
|
||||||
|
|
||||||
|
@ -793,13 +782,12 @@ Labels can be used on containers to override default behaviour:
|
||||||
- `traefik.weight=10`: assign this weight to the container
|
- `traefik.weight=10`: assign this weight to the container
|
||||||
- `traefik.enable=false`: disable this container in Træfɪk
|
- `traefik.enable=false`: disable this container in Træfɪk
|
||||||
- `traefik.frontend.rule=Host:test.traefik.io`: override the default frontend rule (Default: `Host:{containerName}.{domain}`). See [frontends](#frontends).
|
- `traefik.frontend.rule=Host:test.traefik.io`: override the default frontend rule (Default: `Host:{containerName}.{domain}`). See [frontends](#frontends).
|
||||||
- `traefik.frontend.value=test.example.com`: override the default frontend value (Default: `{containerName}.{domain}`) See [frontends](#frontends). Must be associated with label traefik.frontend.rule.
|
|
||||||
- `traefik.frontend.passHostHeader=true`: forward client `Host` header to the backend.
|
- `traefik.frontend.passHostHeader=true`: forward client `Host` header to the backend.
|
||||||
- `traefik.frontend.entryPoints=http,https`: assign this frontend to entry points `http` and `https`. Overrides `defaultEntryPoints`.
|
- `traefik.frontend.entryPoints=http,https`: assign this frontend to entry points `http` and `https`. Overrides `defaultEntryPoints`.
|
||||||
* `traefik.domain=traefik.localhost`: override the default domain
|
* `traefik.domain=traefik.localhost`: override the default domain
|
||||||
|
|
||||||
|
|
||||||
## <a id="marathon"></a> Marathon backend
|
## Marathon backend
|
||||||
|
|
||||||
Træfɪk can be configured to use Marathon as a backend configuration:
|
Træfɪk can be configured to use Marathon as a backend configuration:
|
||||||
|
|
||||||
|
@ -873,13 +861,12 @@ Labels can be used on containers to override default behaviour:
|
||||||
- `traefik.protocol=https`: override the default `http` protocol
|
- `traefik.protocol=https`: override the default `http` protocol
|
||||||
- `traefik.weight=10`: assign this weight to the application
|
- `traefik.weight=10`: assign this weight to the application
|
||||||
- `traefik.enable=false`: disable this application in Træfɪk
|
- `traefik.enable=false`: disable this application in Træfɪk
|
||||||
- `traefik.frontend.rule=Host`: override the default frontend rule (Default: Host). See [frontends](#frontends).
|
- `traefik.frontend.rule=Host:test.traefik.io`: override the default frontend rule (Default: `Host:{containerName}.{domain}`). See [frontends](#frontends).
|
||||||
- `traefik.frontend.value=test.example.com`: override the default frontend value (Default: `{appName}.{domain}`) See [frontends](#frontends). Must be associated with label traefik.frontend.rule.
|
|
||||||
- `traefik.frontend.passHostHeader=true`: forward client `Host` header to the backend.
|
- `traefik.frontend.passHostHeader=true`: forward client `Host` header to the backend.
|
||||||
- `traefik.frontend.entryPoints=http,https`: assign this frontend to entry points `http` and `https`. Overrides `defaultEntryPoints`.
|
- `traefik.frontend.entryPoints=http,https`: assign this frontend to entry points `http` and `https`. Overrides `defaultEntryPoints`.
|
||||||
* `traefik.domain=traefik.localhost`: override the default domain
|
* `traefik.domain=traefik.localhost`: override the default domain
|
||||||
|
|
||||||
## <a id="consul"></a> Consul backend
|
## Consul backend
|
||||||
|
|
||||||
Træfɪk can be configured to use Consul as a backend configuration:
|
Træfɪk can be configured to use Consul as a backend configuration:
|
||||||
|
|
||||||
|
@ -929,48 +916,41 @@ prefix = "traefik"
|
||||||
# insecureskipverify = true
|
# insecureskipverify = true
|
||||||
```
|
```
|
||||||
|
|
||||||
The Keys-Values structure should look (using `prefix = "/traefik"`):
|
Please refer to the [Key Value storage structure](#key-value-storage-structure) section to get documentation en traefik KV structure.
|
||||||
|
|
||||||
- backend 1
|
## Consul catalog backend
|
||||||
|
|
||||||
| Key | Value |
|
Træfɪk can be configured to use service discovery catalog of Consul as a backend configuration:
|
||||||
|--------------------------------------------------------|-----------------------------|
|
|
||||||
| `/traefik/backends/backend1/circuitbreaker/expression` | `NetworkErrorRatio() > 0.5` |
|
|
||||||
| `/traefik/backends/backend1/servers/server1/url` | `http://172.17.0.2:80` |
|
|
||||||
| `/traefik/backends/backend1/servers/server1/weight` | `10` |
|
|
||||||
| `/traefik/backends/backend1/servers/server2/url` | `http://172.17.0.3:80` |
|
|
||||||
| `/traefik/backends/backend1/servers/server2/weight` | `1` |
|
|
||||||
|
|
||||||
- backend 2
|
```toml
|
||||||
|
################################################################
|
||||||
|
# Consul Catalog configuration backend
|
||||||
|
################################################################
|
||||||
|
|
||||||
| Key | Value |
|
# Enable Consul Catalog configuration backend
|
||||||
|-----------------------------------------------------|------------------------|
|
#
|
||||||
| `/traefik/backends/backend2/loadbalancer/method` | `drr` |
|
# Optional
|
||||||
| `/traefik/backends/backend2/servers/server1/url` | `http://172.17.0.4:80` |
|
#
|
||||||
| `/traefik/backends/backend2/servers/server1/weight` | `1` |
|
[consulCatalog]
|
||||||
| `/traefik/backends/backend2/servers/server2/url` | `http://172.17.0.5:80` |
|
|
||||||
| `/traefik/backends/backend2/servers/server2/weight` | `2` |
|
|
||||||
|
|
||||||
- frontend 1
|
# Consul server endpoint
|
||||||
|
#
|
||||||
|
# Required
|
||||||
|
#
|
||||||
|
endpoint = "127.0.0.1:8500"
|
||||||
|
|
||||||
| Key | Value |
|
# Default domain used.
|
||||||
|----------------------------------------------------|------------------|
|
#
|
||||||
| `/traefik/frontends/frontend1/backend` | `backend2` |
|
# Optional
|
||||||
| `/traefik/frontends/frontend1/routes/test_1/rule` | `Host` |
|
#
|
||||||
| `/traefik/frontends/frontend1/routes/test_1/value` | `test.localhost` |
|
domain = "consul.localhost"
|
||||||
|
```
|
||||||
|
|
||||||
- frontend 2
|
This backend will create routes matching on hostname based on the service name
|
||||||
|
used in consul.
|
||||||
| Key | Value |
|
|
||||||
|----------------------------------------------------|------------|
|
|
||||||
| `/traefik/frontends/frontend2/backend` | `backend1` |
|
|
||||||
| `/traefik/frontends/frontend2/passHostHeader` | `true` |
|
|
||||||
| `/traefik/frontends/frontend2/entrypoints` |`http,https`|
|
|
||||||
| `/traefik/frontends/frontend2/routes/test_2/rule` | `Path` |
|
|
||||||
| `/traefik/frontends/frontend2/routes/test_2/value` | `/test` |
|
|
||||||
|
|
||||||
|
|
||||||
## <a id="etcd"></a> Etcd backend
|
## Etcd backend
|
||||||
|
|
||||||
Træfɪk can be configured to use Etcd as a backend configuration:
|
Træfɪk can be configured to use Etcd as a backend configuration:
|
||||||
|
|
||||||
|
@ -1020,79 +1000,10 @@ Træfɪk can be configured to use Etcd as a backend configuration:
|
||||||
# insecureskipverify = true
|
# insecureskipverify = true
|
||||||
```
|
```
|
||||||
|
|
||||||
The Keys-Values structure should look (using `prefix = "/traefik"`):
|
Please refer to the [Key Value storage structure](#key-value-storage-structure) section to get documentation en traefik KV structure.
|
||||||
|
|
||||||
- backend 1
|
|
||||||
|
|
||||||
| Key | Value |
|
|
||||||
|--------------------------------------------------------|-----------------------------|
|
|
||||||
| `/traefik/backends/backend1/circuitbreaker/expression` | `NetworkErrorRatio() > 0.5` |
|
|
||||||
| `/traefik/backends/backend1/servers/server1/url` | `http://172.17.0.2:80` |
|
|
||||||
| `/traefik/backends/backend1/servers/server1/weight` | `10` |
|
|
||||||
| `/traefik/backends/backend1/servers/server2/url` | `http://172.17.0.3:80` |
|
|
||||||
| `/traefik/backends/backend1/servers/server2/weight` | `1` |
|
|
||||||
|
|
||||||
- backend 2
|
|
||||||
|
|
||||||
| Key | Value |
|
|
||||||
|-----------------------------------------------------|------------------------|
|
|
||||||
| `/traefik/backends/backend2/loadbalancer/method` | `drr` |
|
|
||||||
| `/traefik/backends/backend2/servers/server1/url` | `http://172.17.0.4:80` |
|
|
||||||
| `/traefik/backends/backend2/servers/server1/weight` | `1` |
|
|
||||||
| `/traefik/backends/backend2/servers/server2/url` | `http://172.17.0.5:80` |
|
|
||||||
| `/traefik/backends/backend2/servers/server2/weight` | `2` |
|
|
||||||
|
|
||||||
- frontend 1
|
|
||||||
|
|
||||||
| Key | Value |
|
|
||||||
|----------------------------------------------------|------------------|
|
|
||||||
| `/traefik/frontends/frontend1/backend` | `backend2` |
|
|
||||||
| `/traefik/frontends/frontend1/routes/test_1/rule` | `Host` |
|
|
||||||
| `/traefik/frontends/frontend1/routes/test_1/value` | `test.localhost` |
|
|
||||||
|
|
||||||
- frontend 2
|
|
||||||
|
|
||||||
| Key | Value |
|
|
||||||
|----------------------------------------------------|------------|
|
|
||||||
| `/traefik/frontends/frontend2/backend` | `backend1` |
|
|
||||||
| `/traefik/frontends/frontend2/passHostHeader` | `true` |
|
|
||||||
| `/traefik/frontends/frontend2/entrypoints` |`http,https`|
|
|
||||||
| `/traefik/frontends/frontend2/routes/test_2/rule` | `Path` |
|
|
||||||
| `/traefik/frontends/frontend2/routes/test_2/value` | `/test` |
|
|
||||||
|
|
||||||
|
|
||||||
## <a id="consulcatalog"></a> Consul catalog backend
|
## Zookeeper 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"
|
|
||||||
```
|
|
||||||
|
|
||||||
This backend will create routes matching on hostname based on the service name
|
|
||||||
used in consul.
|
|
||||||
|
|
||||||
## <a id="zk"></a> Zookeeper backend
|
|
||||||
|
|
||||||
Træfɪk can be configured to use Zookeeper as a backend configuration:
|
Træfɪk can be configured to use Zookeeper as a backend configuration:
|
||||||
|
|
||||||
|
@ -1131,48 +1042,10 @@ Træfɪk can be configured to use Zookeeper as a backend configuration:
|
||||||
#
|
#
|
||||||
# filename = "zookeeper.tmpl"
|
# filename = "zookeeper.tmpl"
|
||||||
```
|
```
|
||||||
The Keys-Values structure should look (using `prefix = "/traefik"`):
|
|
||||||
|
|
||||||
- backend 1
|
Please refer to the [Key Value storage structure](#key-value-storage-structure) section to get documentation en traefik KV structure.
|
||||||
|
|
||||||
| Key | Value |
|
## BoltDB backend
|
||||||
|--------------------------------------------------------|-----------------------------|
|
|
||||||
| `/traefik/backends/backend1/circuitbreaker/expression` | `NetworkErrorRatio() > 0.5` |
|
|
||||||
| `/traefik/backends/backend1/servers/server1/url` | `http://172.17.0.2:80` |
|
|
||||||
| `/traefik/backends/backend1/servers/server1/weight` | `10` |
|
|
||||||
| `/traefik/backends/backend1/servers/server2/url` | `http://172.17.0.3:80` |
|
|
||||||
| `/traefik/backends/backend1/servers/server2/weight` | `1` |
|
|
||||||
|
|
||||||
- backend 2
|
|
||||||
|
|
||||||
| Key | Value |
|
|
||||||
|-----------------------------------------------------|------------------------|
|
|
||||||
| `/traefik/backends/backend2/loadbalancer/method` | `drr` |
|
|
||||||
| `/traefik/backends/backend2/servers/server1/url` | `http://172.17.0.4:80` |
|
|
||||||
| `/traefik/backends/backend2/servers/server1/weight` | `1` |
|
|
||||||
| `/traefik/backends/backend2/servers/server2/url` | `http://172.17.0.5:80` |
|
|
||||||
| `/traefik/backends/backend2/servers/server2/weight` | `2` |
|
|
||||||
|
|
||||||
- frontend 1
|
|
||||||
|
|
||||||
| Key | Value |
|
|
||||||
|---------------------------------------------------|------------------|
|
|
||||||
| `/traefik/frontends/frontend1/backend | `backend2` |
|
|
||||||
| `/traefik/frontends/frontend1/routes/test_1/rule | `Host` |
|
|
||||||
| `/traefik/frontends/frontend1/routes/test_1/value | `test.localhost` |
|
|
||||||
|
|
||||||
- frontend 2
|
|
||||||
|
|
||||||
| Key | Value |
|
|
||||||
|----------------------------------------------------|------------|
|
|
||||||
| `/traefik/frontends/frontend2/backend` | `backend1` |
|
|
||||||
| `/traefik/frontends/frontend2/passHostHeader` | `true` |
|
|
||||||
| `/traefik/frontends/frontend2/entrypoints` |`http,https`|
|
|
||||||
| `/traefik/frontends/frontend2/routes/test_2/rule` | `Path` |
|
|
||||||
| `/traefik/frontends/frontend2/routes/test_2/value` | `/test` |
|
|
||||||
|
|
||||||
|
|
||||||
## <a id="boltdb"></a> BoltDB backend
|
|
||||||
|
|
||||||
Træfɪk can be configured to use BoltDB as a backend configuration:
|
Træfɪk can be configured to use BoltDB as a backend configuration:
|
||||||
|
|
||||||
|
@ -1212,7 +1085,49 @@ Træfɪk can be configured to use BoltDB as a backend configuration:
|
||||||
# filename = "boltdb.tmpl"
|
# filename = "boltdb.tmpl"
|
||||||
```
|
```
|
||||||
|
|
||||||
## <a id="atomicconfig"></a> Atomic configuration changes
|
Please refer to the [Key Value storage structure](#key-value-storage-structure) section to get documentation en traefik KV structure.
|
||||||
|
|
||||||
|
## Key-value storage structure
|
||||||
|
|
||||||
|
The Keys-Values structure should look (using `prefix = "/traefik"`):
|
||||||
|
|
||||||
|
- backend 1
|
||||||
|
|
||||||
|
| Key | Value |
|
||||||
|
|--------------------------------------------------------|-----------------------------|
|
||||||
|
| `/traefik/backends/backend1/circuitbreaker/expression` | `NetworkErrorRatio() > 0.5` |
|
||||||
|
| `/traefik/backends/backend1/servers/server1/url` | `http://172.17.0.2:80` |
|
||||||
|
| `/traefik/backends/backend1/servers/server1/weight` | `10` |
|
||||||
|
| `/traefik/backends/backend1/servers/server2/url` | `http://172.17.0.3:80` |
|
||||||
|
| `/traefik/backends/backend1/servers/server2/weight` | `1` |
|
||||||
|
|
||||||
|
- backend 2
|
||||||
|
|
||||||
|
| Key | Value |
|
||||||
|
|-----------------------------------------------------|------------------------|
|
||||||
|
| `/traefik/backends/backend2/loadbalancer/method` | `drr` |
|
||||||
|
| `/traefik/backends/backend2/servers/server1/url` | `http://172.17.0.4:80` |
|
||||||
|
| `/traefik/backends/backend2/servers/server1/weight` | `1` |
|
||||||
|
| `/traefik/backends/backend2/servers/server2/url` | `http://172.17.0.5:80` |
|
||||||
|
| `/traefik/backends/backend2/servers/server2/weight` | `2` |
|
||||||
|
|
||||||
|
- frontend 1
|
||||||
|
|
||||||
|
| Key | Value |
|
||||||
|
|---------------------------------------------------|-----------------------|
|
||||||
|
| `/traefik/frontends/frontend1/backend` | `backend2` |
|
||||||
|
| `/traefik/frontends/frontend1/routes/test_1/rule` | `Host:test.localhost` |
|
||||||
|
|
||||||
|
- frontend 2
|
||||||
|
|
||||||
|
| Key | Value |
|
||||||
|
|----------------------------------------------------|--------------|
|
||||||
|
| `/traefik/frontends/frontend2/backend` | `backend1` |
|
||||||
|
| `/traefik/frontends/frontend2/passHostHeader` | `true` |
|
||||||
|
| `/traefik/frontends/frontend2/entrypoints` | `http,https` |
|
||||||
|
| `/traefik/frontends/frontend2/routes/test_2/rule` | `Path:/test` |
|
||||||
|
|
||||||
|
## Atomic configuration changes
|
||||||
|
|
||||||
The [Etcd](https://github.com/coreos/etcd/issues/860) and [Consul](https://github.com/hashicorp/consul/issues/886) backends do not support updating multiple keys atomically. As a result, it may be possible for Træfɪk to read an intermediate configuration state despite judicious use of the `--providersThrottleDuration` flag. To solve this problem, Træfɪk supports a special key called `/traefik/alias`. If set, Træfɪk use the value as an alternative key prefix.
|
The [Etcd](https://github.com/coreos/etcd/issues/860) and [Consul](https://github.com/hashicorp/consul/issues/886) backends do not support updating multiple keys atomically. As a result, it may be possible for Træfɪk to read an intermediate configuration state despite judicious use of the `--providersThrottleDuration` flag. To solve this problem, Træfɪk supports a special key called `/traefik/alias`. If set, Træfɪk use the value as an alternative key prefix.
|
||||||
|
|
||||||
|
@ -1251,7 +1166,7 @@ Once the `/traefik/alias` key is updated, the new `/traefik_configurations/2` co
|
||||||
Note that Træfɪk *will not watch for key changes in the `/traefik_configurations` prefix*. It will only watch for changes in the `/traefik` prefix. Further, if the `/traefik/alias` key is set, all other sibling keys with the `/traefik` prefix are ignored.
|
Note that Træfɪk *will not watch for key changes in the `/traefik_configurations` prefix*. It will only watch for changes in the `/traefik` prefix. Further, if the `/traefik/alias` key is set, all other sibling keys with the `/traefik` prefix are ignored.
|
||||||
|
|
||||||
|
|
||||||
## <a id="benchmarks"></a> Benchmarks
|
## Benchmarks
|
||||||
|
|
||||||
Here are some early Benchmarks between Nginx, HA-Proxy and Træfɪk acting as simple load balancers between two servers.
|
Here are some early Benchmarks between Nginx, HA-Proxy and Træfɪk acting as simple load balancers between two servers.
|
||||||
|
|
||||||
|
|
|
@ -166,7 +166,7 @@ func (provider *Docker) getFrontendRule(container docker.Container) string {
|
||||||
// ⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠
|
// ⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠
|
||||||
// TODO: backwards compatibility with DEPRECATED rule.Value
|
// TODO: backwards compatibility with DEPRECATED rule.Value
|
||||||
if value, ok := container.Config.Labels["traefik.frontend.value"]; ok {
|
if value, ok := container.Config.Labels["traefik.frontend.value"]; ok {
|
||||||
log.Warnf("Label traefik.frontend.value=%s is DEPRECATED, please refer to the rule label: https://github.com/containous/traefik/blob/master/docs/index.md#docker", value)
|
log.Warnf("Label traefik.frontend.value=%s is DEPRECATED (will be removed in v1.0.0), please refer to the rule label: https://github.com/containous/traefik/blob/master/docs/index.md#docker", value)
|
||||||
rule, _ := container.Config.Labels["traefik.frontend.rule"]
|
rule, _ := container.Config.Labels["traefik.frontend.rule"]
|
||||||
return rule + ":" + value
|
return rule + ":" + value
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,20 +21,18 @@ git config --global user.email "emile@vauge.com"
|
||||||
git config --global user.name "Emile Vauge"
|
git config --global user.name "Emile Vauge"
|
||||||
git clone https://github.com/containous/traefik-library-image.git
|
git clone https://github.com/containous/traefik-library-image.git
|
||||||
cd traefik-library-image
|
cd traefik-library-image
|
||||||
git remote rm origin
|
|
||||||
git remote add origin https://emilevauge:${GITHUB_TOKEN}@github.com/containous/traefik-library-image.git
|
|
||||||
./update.sh $VERSION
|
./update.sh $VERSION
|
||||||
git add -A
|
git add -A
|
||||||
echo $VERSION | git commit --file -
|
echo $VERSION | git commit --file -
|
||||||
echo $VERSION | git tag -a $VERSION --file -
|
echo $VERSION | git tag -a $VERSION --file -
|
||||||
git push --follow-tags -u origin master
|
git push -q --follow-tags https://emilevauge:${GITHUB_TOKEN}@github.com/containous/traefik-library-image.git
|
||||||
|
|
||||||
# create docker image emilevauge/traefik (compatibility)
|
# create docker image emilevauge/traefik (compatibility)
|
||||||
docker login -e $DOCKER_EMAIL -u $DOCKER_USER -p $DOCKER_PASS
|
docker login -e $DOCKER_EMAIL -u $DOCKER_USER -p $DOCKER_PASS
|
||||||
docker tag containous/traefik emilevauge/traefik:latest
|
docker tag containous/traefik emilevauge/traefik:latest
|
||||||
docker push emilevauge/traefik:latest
|
docker push emilevauge/traefik:latest
|
||||||
docker tag emilevauge/traefik:latest emilevauge/traefik:${VERSION}
|
docker tag emilevauge/traefik:latest emilevauge/traefik:${VERSION}
|
||||||
docker push emilevauge/traefik:${VERSION}
|
docker push -q emilevauge/traefik:${VERSION}
|
||||||
|
|
||||||
cd ..
|
cd ..
|
||||||
rm -Rf traefik-library-image/
|
rm -Rf traefik-library-image/
|
||||||
|
|
|
@ -517,7 +517,7 @@ func getRoute(serverRoute *serverRoute, route *types.Route) error {
|
||||||
// TODO: backwards compatibility with DEPRECATED rule.Value
|
// TODO: backwards compatibility with DEPRECATED rule.Value
|
||||||
if len(route.Value) > 0 {
|
if len(route.Value) > 0 {
|
||||||
route.Rule += ":" + route.Value
|
route.Rule += ":" + route.Value
|
||||||
log.Warnf("Value %s is DEPRECATED, please refer to the new frontend notation: https://github.com/containous/traefik/blob/master/docs/index.md#-frontends", route.Value)
|
log.Warnf("Value %s is DEPRECATED (will be removed in v1.0.0), please refer to the new frontend notation: https://github.com/containous/traefik/blob/master/docs/index.md#-frontends", route.Value)
|
||||||
}
|
}
|
||||||
// ⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠
|
// ⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠⚠
|
||||||
|
|
||||||
|
|
|
@ -513,17 +513,14 @@
|
||||||
# [frontends.frontend1]
|
# [frontends.frontend1]
|
||||||
# backend = "backend2"
|
# backend = "backend2"
|
||||||
# [frontends.frontend1.routes.test_1]
|
# [frontends.frontend1.routes.test_1]
|
||||||
# rule = "Host"
|
# rule = "Host:test.localhost"
|
||||||
# value = "test.localhost"
|
|
||||||
# [frontends.frontend2]
|
# [frontends.frontend2]
|
||||||
# backend = "backend1"
|
# backend = "backend1"
|
||||||
# passHostHeader = true
|
# passHostHeader = true
|
||||||
# entrypoints = ["https"] # overrides defaultEntryPoints
|
# entrypoints = ["https"] # overrides defaultEntryPoints
|
||||||
# [frontends.frontend2.routes.test_1]
|
# [frontends.frontend2.routes.test_1]
|
||||||
# rule = "Host"
|
# rule = "Host:{subdomain:[a-z]+}.localhost"
|
||||||
# value = "{subdomain:[a-z]+}.localhost"
|
|
||||||
# [frontends.frontend3]
|
# [frontends.frontend3]
|
||||||
# entrypoints = ["http", "https"] # overrides defaultEntryPoints
|
# entrypoints = ["http", "https"] # overrides defaultEntryPoints
|
||||||
# backend = "backend2"
|
# backend = "backend2"
|
||||||
# rule = "Path"
|
# rule = "Path:/test"
|
||||||
# value = "/test"
|
|
Loading…
Reference in a new issue