Use the same case everywhere

This commit is contained in:
Ludovic Fernandez 2019-07-01 11:30:05 +02:00 committed by Traefiker Bot
parent f6436663eb
commit c7d336f958
179 changed files with 5118 additions and 4436 deletions

View file

@ -14,7 +14,7 @@ For this very reason, the sendAnonymousUsage option is mandatory: we want you to
??? example "Enabling Data Collection with TOML" ??? example "Enabling Data Collection with TOML"
```toml ```toml
[Global] [global]
# Send anonymous usage data # Send anonymous usage data
sendAnonymousUsage = true sendAnonymousUsage = true
``` ```
@ -56,19 +56,18 @@ Once a day (the first call begins 10 minutes after the start of Traefik), we col
[api] [api]
[Docker] [providers.docker]
endpoint = "tcp://10.10.10.10:2375" endpoint = "tcp://10.10.10.10:2375"
domain = "foo.bir"
exposedByDefault = true exposedByDefault = true
swarmMode = true swarmMode = true
[Docker.TLS] [providers.docker.TLS]
ca = "dockerCA" ca = "dockerCA"
cert = "dockerCert" cert = "dockerCert"
key = "dockerKey" key = "dockerKey"
insecureSkipVerify = true insecureSkipVerify = true
[ECS] [providers.ecs]
domain = "foo.bar" domain = "foo.bar"
exposedByDefault = true exposedByDefault = true
clusters = ["foo-bar"] clusters = ["foo-bar"]
@ -86,19 +85,19 @@ Once a day (the first call begins 10 minutes after the start of Traefik), we col
[api] [api]
[Docker] [providers.docker]
endpoint = "xxxx" endpoint = "xxxx"
domain = "xxxx" domain = "xxxx"
exposedByDefault = true exposedByDefault = true
swarmMode = true swarmMode = true
[Docker.TLS] [providers.docker.TLS]
ca = "xxxx" ca = "xxxx"
cert = "xxxx" cert = "xxxx"
key = "xxxx" key = "xxxx"
insecureSkipVerify = false insecureSkipVerify = false
[ECS] [providers.ecs]
domain = "xxxx" domain = "xxxx"
exposedByDefault = true exposedByDefault = true
clusters = [] clusters = []

View file

@ -14,13 +14,18 @@ version: '3'
services: services:
reverse-proxy: reverse-proxy:
image: traefik:v2.0 # The official v2.0 Traefik docker image # The official v2.0 Traefik docker image
command: --api --providers.docker # Enables the web UI and tells Traefik to listen to docker image: traefik:v2.0
# Enables the web UI and tells Traefik to listen to docker
command: --api --providers.docker
ports: ports:
- "80:80" # The HTTP port # The HTTP port
- "8080:8080" # The Web UI (enabled by --api) - "80:80"
# The Web UI (enabled by --api)
- "8080:8080"
volumes: volumes:
- /var/run/docker.sock:/var/run/docker.sock # So that Traefik can listen to the Docker events # So that Traefik can listen to the Docker events
- /var/run/docker.sock:/var/run/docker.sock
``` ```
**That's it. Now you can launch Traefik!** **That's it. Now you can launch Traefik!**
@ -42,7 +47,8 @@ Edit your `docker-compose.yml` file and add the following at the end of your fil
```yaml ```yaml
# ... # ...
whoami: whoami:
image: containous/whoami # A container that exposes an API to show its IP address # A container that exposes an API to show its IP address
image: containous/whoami
labels: labels:
- "traefik.http.routers.whoami.rule=Host(`whoami.docker.localhost`)" - "traefik.http.routers.whoami.rule=Host(`whoami.docker.localhost`)"
``` ```

View file

@ -12,7 +12,7 @@ You can configure Traefik to use an ACME provider (like Let's Encrypt) for autom
??? example "Enabling ACME" ??? example "Enabling ACME"
```toml ```toml tab="TOML"
[entryPoints] [entryPoints]
[entryPoints.web] [entryPoints.web]
address = ":80" address = ":80"
@ -20,17 +20,39 @@ You can configure Traefik to use an ACME provider (like Let's Encrypt) for autom
[entryPoints.http-tls] [entryPoints.http-tls]
address = ":443" address = ":443"
[acme] # every router with TLS enabled will now be able to use ACME for its certificates # every router with TLS enabled will now be able to use ACME for its certificates
[acme]
email = "your-email@your-domain.org" email = "your-email@your-domain.org"
storage = "acme.json" storage = "acme.json"
onHostRule = true # dynamic generation based on the Host() & HostSNI() matchers # dynamic generation based on the Host() & HostSNI() matchers
onHostRule = true
[acme.httpChallenge] [acme.httpChallenge]
entryPoint = "web" # used during the challenge # used during the challenge
entryPoint = "web"
```
```yaml tab="YAML"
entryPoints:
web:
address: ":80"
http-tls:
address: ":443"
# every router with TLS enabled will now be able to use ACME for its certificates
acme:
email: your-email@your-domain.org
storage: acme.json
# dynamic generation based on the Host() & HostSNI() matchers
onHostRule: true
httpChallenge:
# used during the challenge
entryPoint: web
``` ```
??? example "Configuring Wildcard Certificates" ??? example "Configuring Wildcard Certificates"
```toml ```toml tab="TOML"
[entryPoints] [entryPoints]
[entryPoints.web] [entryPoints.web]
address = ":80" address = ":80"
@ -49,19 +71,44 @@ You can configure Traefik to use an ACME provider (like Let's Encrypt) for autom
sans = ["mydomain.com"] sans = ["mydomain.com"]
``` ```
```yaml tab="YAML"
entryPoints:
web:
address: ":80"
http-tls:
address: ":443"
acme:
email: your-email@your-domain.org
storage: acme.json
dnsChallenge:
provide: xxx
domains:
- main: "*.mydomain.com"
sans:
- mydomain.com
```
??? note "Configuration Reference" ??? note "Configuration Reference"
There are many available options for ACME. For a quick glance at what's possible, browse the configuration reference: There are many available options for ACME.
For a quick glance at what's possible, browse the configuration reference:
```toml ```toml tab="TOML"
--8<-- "content/https/ref-acme.toml" --8<-- "content/https/ref-acme.toml"
``` ```
```yaml tab="YAML"
--8<-- "content/https/ref-acme.yaml"
```
## Automatic Renewals ## Automatic Renewals
Traefik automatically tracks the expiry date of ACME certificates it generates. Traefik automatically tracks the expiry date of ACME certificates it generates.
If there are less than 30 days remaining before the certificate expires, Traefik will attempt to rewnew it automatically. If there are less than 30 days remaining before the certificate expires, Traefik will attempt to renew it automatically.
!!! note !!! note
Certificates that are no longer used may still be renewed, as Traefik does not currently check if the certificate is being used before renewing. Certificates that are no longer used may still be renewed, as Traefik does not currently check if the certificate is being used before renewing.
@ -77,11 +124,16 @@ when using the `TLS-ALPN-01` challenge, Traefik must be reachable by Let's Encry
??? example "Configuring the `tlsChallenge`" ??? example "Configuring the `tlsChallenge`"
```toml ```toml tab="TOML"
[acme] [acme]
[acme.tlsChallenge] [acme.tlsChallenge]
``` ```
```yaml tab="YAML"
acme:
tlsChallenge: {}
```
### `httpChallenge` ### `httpChallenge`
Use the `HTTP-01` challenge to generate and renew ACME certificates by provisioning an HTTP resource under a well-known URI. Use the `HTTP-01` challenge to generate and renew ACME certificates by provisioning an HTTP resource under a well-known URI.
@ -91,13 +143,20 @@ when using the `HTTP-01` challenge, `acme.httpChallenge.entryPoint` must be reac
??? example "Using an EntryPoint Called http for the `httpChallenge`" ??? example "Using an EntryPoint Called http for the `httpChallenge`"
```toml ```toml tab="TOML"
[acme] [acme]
# ... # ...
[acme.httpChallenge] [acme.httpChallenge]
entryPoint = "http" entryPoint = "http"
``` ```
```yaml tab="YAML"
acme:
# ...
httpChallenge:
entryPoint: http
```
!!! note !!! note
Redirection is fully compatible with the `HTTP-01` challenge. Redirection is fully compatible with the `HTTP-01` challenge.
@ -107,7 +166,7 @@ Use the `DNS-01` challenge to generate and renew ACME certificates by provisioni
??? example "Configuring a `dnsChallenge` with the DigitalOcean Provider" ??? example "Configuring a `dnsChallenge` with the DigitalOcean Provider"
```toml ```toml tab="TOML"
[acme] [acme]
# ... # ...
[acme.dnsChallenge] [acme.dnsChallenge]
@ -116,6 +175,15 @@ Use the `DNS-01` challenge to generate and renew ACME certificates by provisioni
# ... # ...
``` ```
```yaml tab="YAML"
acme:
# ...
dnsChallenge:
provider: digitalocean
delayBeforeCheck: 0
# ...
```
!!! important !!! important
A `provider` is mandatory. A `provider` is mandatory.
@ -200,7 +268,7 @@ For example, `CF_API_EMAIL_FILE=/run/secrets/traefik_cf-api-email` could be used
Use custom DNS servers to resolve the FQDN authority. Use custom DNS servers to resolve the FQDN authority.
```toml ```toml tab="TOML"
[acme] [acme]
# ... # ...
[acme.dnsChallenge] [acme.dnsChallenge]
@ -208,12 +276,22 @@ Use custom DNS servers to resolve the FQDN authority.
resolvers = ["1.1.1.1:53", "8.8.8.8:53"] resolvers = ["1.1.1.1:53", "8.8.8.8:53"]
``` ```
```yaml tab="YAML"
acme:
# ...
dnsChallenge:
# ...
resolvers:
- "1.1.1.1:53"
- "8.8.8.8:53"
```
#### Wildcard Domains #### Wildcard Domains
[ACME V2](https://community.letsencrypt.org/t/acme-v2-and-wildcard-certificate-support-is-live/55579) supports wildcard certificates. [ACME V2](https://community.letsencrypt.org/t/acme-v2-and-wildcard-certificate-support-is-live/55579) supports wildcard certificates.
As described in [Let's Encrypt's post](https://community.letsencrypt.org/t/staging-endpoint-for-acme-v2/49605) wildcard certificates can only be generated through a [`DNS-01` challenge](#dnschallenge). As described in [Let's Encrypt's post](https://community.letsencrypt.org/t/staging-endpoint-for-acme-v2/49605) wildcard certificates can only be generated through a [`DNS-01` challenge](#dnschallenge).
```toml ```toml tab="TOML"
[acme] [acme]
# ... # ...
[[acme.domains]] [[acme.domains]]
@ -223,6 +301,17 @@ As described in [Let's Encrypt's post](https://community.letsencrypt.org/t/stagi
# ... # ...
``` ```
```yaml tab="YAML"
acme:
# ...
domains:
- main: "*.local1.com"
sans:
- local1.com
# ...
```
!!! note "Double Wildcard Certificates" !!! note "Double Wildcard Certificates"
It is not possible to request a double wildcard certificate for a domain (for example `*.*.local.com`). It is not possible to request a double wildcard certificate for a domain (for example `*.*.local.com`).
@ -240,7 +329,7 @@ You can set SANs (alternative domains) for each main domain.
Every domain must have A/AAAA records pointing to Traefik. Every domain must have A/AAAA records pointing to Traefik.
Each domain & SAN will lead to a certificate request. Each domain & SAN will lead to a certificate request.
```toml ```toml tab="TOML"
[acme] [acme]
# ... # ...
[[acme.domains]] [[acme.domains]]
@ -254,6 +343,22 @@ Each domain & SAN will lead to a certificate request.
# ... # ...
``` ```
```yaml tab="YAML"
acme:
# ...
domains:
- main: "local1.com"
sans:
- "test1.local1.com"
- "test2.local1.com"
- main: "local2.com"
- main: "*.local3.com"
sans:
- "local3.com"
- "test1.test1.local3.com"
# ...
```
!!! important !!! important
The certificates for the domains listed in `acme.domains` are negotiated at Traefik startup only. The certificates for the domains listed in `acme.domains` are negotiated at Traefik startup only.
@ -264,26 +369,40 @@ Each domain & SAN will lead to a certificate request.
??? example "Using the Let's Encrypt staging server" ??? example "Using the Let's Encrypt staging server"
```toml ```toml tab="TOML"
[acme] [acme]
# ... # ...
caServer = "https://acme-staging-v02.api.letsencrypt.org/directory" caServer = "https://acme-staging-v02.api.letsencrypt.org/directory"
# ... # ...
``` ```
```yaml tab="YAML"
acme:
# ...
caServer: https://acme-staging-v02.api.letsencrypt.org/directory
# ...
```
## `onHostRule` ## `onHostRule`
Enable certificate generation on [routers](../routing/routers/index.md) `Host` & `HostSNI` rules. Enable certificate generation on [routers](../routing/routers/index.md) `Host` & `HostSNI` rules.
This will request a certificate from Let's Encrypt for each router with a Host rule. This will request a certificate from Let's Encrypt for each router with a Host rule.
```toml ```toml tab="TOML"
[acme] [acme]
# ... # ...
onHostRule = true onHostRule = true
# ... # ...
``` ```
```yaml tab="YAML"
acme:
# ...
onHostRule: true
# ...
```
!!! note "Multiple Hosts in a Rule" !!! note "Multiple Hosts in a Rule"
The rule `Host(test1.traefik.io,test2.traefik.io)` will request a certificate with the main domain `test1.traefik.io` and SAN `test2.traefik.io`. The rule `Host(test1.traefik.io,test2.traefik.io)` will request a certificate with the main domain `test1.traefik.io` and SAN `test2.traefik.io`.
@ -294,17 +413,23 @@ This will request a certificate from Let's Encrypt for each router with a Host r
The `storage` option sets the location where your ACME certificates are saved to. The `storage` option sets the location where your ACME certificates are saved to.
```toml ```toml tab="TOML"
[acme] [acme]
# ... # ...
storage = "acme.json" storage = "acme.json"
# ... # ...
``` ```
The value can refer to two kinds of storage: ```yaml tab="YAML"
acme
# ...
storage: acme.json
# ...
```
The value can refer to some kinds of storage:
- a JSON file - a JSON file
- a KV store entry
### In a File ### In a File
@ -323,19 +448,6 @@ docker run -v "/my/host/acme:/etc/traefik/acme" traefik
!!! warning !!! warning
For concurrency reason, this file cannot be shared across multiple instances of Traefik. Use a key value store entry instead. For concurrency reason, this file cannot be shared across multiple instances of Traefik. Use a key value store entry instead.
### In a a Key Value Store Entry
ACME certificates can be stored in a key-value store entry.
```toml
storage = "traefik/acme/account"
```
!!! note "Storage Size"
Because key-value stores have limited entry size, the certificates list is compressed _before_ it is saved.
For example, it is possible to store up to _approximately_ 100 ACME certificates in Consul.
## Fallback ## Fallback
If Let's Encrypt is not reachable, the following certificates will apply: If Let's Encrypt is not reachable, the following certificates will apply:

View file

@ -7,31 +7,11 @@
# #
email = "test@traefik.io" email = "test@traefik.io"
# File used for certificates storage.
#
# Optional (Deprecated)
#
#storageFile = "acme.json"
# File or key used for certificates storage. # File or key used for certificates storage.
# #
# Required # Required
# #
storage = "acme.json" storage = "acme.json"
# or `storage = "traefik/acme/account"` if using KV store.
# Deprecated, replaced by [acme.dnsChallenge].
#
# Optional.
#
# dnsProvider = "digitalocean"
# Deprecated, replaced by [acme.dnsChallenge.delayBeforeCheck].
#
# Optional
# Default: 0
#
# delayDontCheckDNS = 0
# If true, display debug log messages from the acme client library. # If true, display debug log messages from the acme client library.
# #
@ -47,14 +27,7 @@ storage = "acme.json"
# #
# overrideCertificates = true # overrideCertificates = true
# Deprecated. Enable on demand certificate generation. # Enable certificate generation on routers host rules.
#
# Optional
# Default: false
#
# onDemand = true
# Enable certificate generation on frontends host rules.
# #
# Optional # Optional
# Default: false # Default: false
@ -95,7 +68,7 @@ storage = "acme.json"
# #
# Required # Required
# #
# entryPoint = "http" # entryPoint = "web"
# Use a DNS-01 ACME challenge rather than HTTP-01 challenge. # Use a DNS-01 ACME challenge rather than HTTP-01 challenge.
# Note: mandatory for wildcard certificate generation. # Note: mandatory for wildcard certificate generation.

View file

@ -0,0 +1,127 @@
# Enable ACME (Let's Encrypt): automatic SSL.
acme:
# Email address used for registration.
#
# Required
#
email: "test@traefik.io"
# File or key used for certificates storage.
#
# Required
#
storage: "acme.json"
# If true, display debug log messages from the acme client library.
#
# Optional
# Default: false
#
# acmeLogging: true
# If true, override certificates in key-value store when using storeconfig.
#
# Optional
# Default: false
#
# overrideCertificates: true
# Enable certificate generation on routers host rules.
#
# Optional
# Default: false
#
# onHostRule: true
# CA server to use.
# Uncomment the line to use Let's Encrypt's staging server,
# leave commented to go to prod.
#
# Optional
# Default: "https://acme-v02.api.letsencrypt.org/directory"
#
# caServer: "https://acme-staging-v02.api.letsencrypt.org/directory"
# KeyType to use.
#
# Optional
# Default: "RSA4096"
#
# Available values : "EC256", "EC384", "RSA2048", "RSA4096", "RSA8192"
#
# KeyType: RSA4096
# Use a TLS-ALPN-01 ACME challenge.
#
# Optional (but recommended)
#
tlsChallenge:
# Use a HTTP-01 ACME challenge.
#
# Optional
#
# httpChallenge:
# EntryPoint to use for the HTTP-01 challenges.
#
# Required
#
# entryPoint: web
# Use a DNS-01 ACME challenge rather than HTTP-01 challenge.
# Note: mandatory for wildcard certificate generation.
#
# Optional
#
# dnsChallenge:
# DNS provider used.
#
# Required
#
# provider: digitalocean
# By default, the provider will verify the TXT DNS challenge record before letting ACME verify.
# If delayBeforeCheck is greater than zero, this check is delayed for the configured duration in seconds.
# Useful if internal networks block external DNS queries.
#
# Optional
# Default: 0
#
# delayBeforeCheck: 0
# Use following DNS servers to resolve the FQDN authority.
#
# Optional
# Default: empty
#
# resolvers
# - "1.1.1.1:53"
# - "8.8.8.8:53"
# Disable the DNS propagation checks before notifying ACME that the DNS challenge is ready.
#
# NOT RECOMMENDED:
# Increase the risk of reaching Let's Encrypt's rate limits.
#
# Optional
# Default: false
#
# disablePropagationCheck: true
# Domains list.
# Only domains defined here can generate wildcard certificates.
# The certificates for these domains are negotiated at traefik startup only.
#
# domains:
# - main: "local1.com"
# sans:
# - "test1.local1.com"
# - "test2.local1.com"
# - main: "local2.com"
# - main: "*.local3.com"
# sans:
# - "local3.com"
# - "test1.test1.local3.com"

View file

@ -13,7 +13,7 @@ See the [Let's Encrypt](./acme.md) page.
To add / remove TLS certificates, even when Traefik is already running, their definition can be added to the [dynamic configuration](../getting-started/configuration-overview.md), in the `[[tls.certificates]]` section: To add / remove TLS certificates, even when Traefik is already running, their definition can be added to the [dynamic configuration](../getting-started/configuration-overview.md), in the `[[tls.certificates]]` section:
```toml ```toml tab="TOML"
[[tls.certificates]] [[tls.certificates]]
certFile = "/path/to/domain.cert" certFile = "/path/to/domain.cert"
keyFile = "/path/to/domain.key" keyFile = "/path/to/domain.key"
@ -23,6 +23,15 @@ To add / remove TLS certificates, even when Traefik is already running, their de
keyFile = "/path/to/other-domain.key" keyFile = "/path/to/other-domain.key"
``` ```
```yaml tab="YAML"
tls:
certificates:
- certFile: /path/to/domain.cert
keyFile: /path/to/domain.key
- certFile: /path/to/other-domain.cert
keyFile: /path/to/other-domain.key
```
!!! important "File Provider Only" !!! important "File Provider Only"
In the above example, we've used the [file provider](../providers/file.md) to handle these definitions. In the above example, we've used the [file provider](../providers/file.md) to handle these definitions.
@ -32,23 +41,29 @@ To add / remove TLS certificates, even when Traefik is already running, their de
In Traefik, certificates are grouped together in certificates stores, which are defined as such: In Traefik, certificates are grouped together in certificates stores, which are defined as such:
```toml ```toml tab="TOML"
[tls.stores] [tls.stores]
[tls.stores.default] [tls.stores.default]
``` ```
```yaml tab="YAML"
tls:
stores:
default: {}
```
!!! important "Alpha restriction" !!! important "Alpha restriction"
During the alpha version, any store definition other than the default one (named `default`) will be ignored, During the alpha version, any store definition other than the default one (named `default`) will be ignored,
and there is thefore only one globally available TLS store. and there is thefore only one globally available TLS store.
In the `[[tls.certificates]]` section, a list of stores can then be specified to indicate where the certificates should be stored: In the `tls.certificates` section, a list of stores can then be specified to indicate where the certificates should be stored:
```toml ```toml tab="TOML"
[[tls.certificates]] [[tls.certificates]]
stores = ["default"]
certFile = "/path/to/domain.cert" certFile = "/path/to/domain.cert"
keyFile = "/path/to/domain.key" keyFile = "/path/to/domain.key"
stores = ["default"]
[[tls.certificates]] [[tls.certificates]]
# Note that since no store is defined, # Note that since no store is defined,
@ -57,6 +72,19 @@ In the `[[tls.certificates]]` section, a list of stores can then be specified to
keyFile = "/path/to/other-domain.key" keyFile = "/path/to/other-domain.key"
``` ```
```yaml tab="YAML"
tls:
certificates:
- certFile: /path/to/domain.cert
keyFile: /path/to/domain.key
stores:
- default
# Note that since no store is defined,
# the certificate below will be stored in the `default` store.
- certFile: /path/to/other-domain.cert
keyFile: /path/to/other-domain.key
```
!!! important "Alpha restriction" !!! important "Alpha restriction"
During the alpha version, the `stores` list will actually be ignored and automatically set to `["default"]`. During the alpha version, the `stores` list will actually be ignored and automatically set to `["default"]`.
@ -66,7 +94,7 @@ In the `[[tls.certificates]]` section, a list of stores can then be specified to
Traefik can use a default certificate for connections without a SNI, or without a matching domain. Traefik can use a default certificate for connections without a SNI, or without a matching domain.
This default certificate should be defined in a TLS store: This default certificate should be defined in a TLS store:
```toml ```toml tab="TOML"
[tls.stores] [tls.stores]
[tls.stores.default] [tls.stores.default]
[tls.stores.default.defaultCertificate] [tls.stores.default.defaultCertificate]
@ -74,6 +102,15 @@ This default certificate should be defined in a TLS store:
keyFile = "path/to/cert.key" keyFile = "path/to/cert.key"
``` ```
```yaml tab="YAML"
tls:
stores:
default:
defaultCertificate:
certFile: path/to/cert.crt
keyFile: path/to/cert.key
```
If no default certificate is provided, Traefik generates and uses a self-signed certificate. If no default certificate is provided, Traefik generates and uses a self-signed certificate.
## TLS Options ## TLS Options
@ -82,7 +119,7 @@ The TLS options allow one to configure some parameters of the TLS connection.
### Minimum TLS Version ### Minimum TLS Version
```toml ```toml tab="TOML"
[tls.options] [tls.options]
[tls.options.default] [tls.options.default]
@ -92,6 +129,16 @@ The TLS options allow one to configure some parameters of the TLS connection.
minVersion = "VersionTLS13" minVersion = "VersionTLS13"
``` ```
```yaml tab="YAML"
tls:
options:
default:
minVersion: VersionTLS12
mintls13:
minVersion: VersionTLS13
```
### Mutual Authentication ### Mutual Authentication
Traefik supports both optional and strict (which is the default) mutual authentication, though the `ClientCA.files` section. Traefik supports both optional and strict (which is the default) mutual authentication, though the `ClientCA.files` section.
@ -102,20 +149,32 @@ For clients with a certificate, the `optional` option governs the behaviour as f
- When `optional = false`, Traefik accepts connections only from clients presenting a certificate signed by a CA listed in `ClientCA.files`. - When `optional = false`, Traefik accepts connections only from clients presenting a certificate signed by a CA listed in `ClientCA.files`.
- When `optional = true`, Traefik authorizes connections from clients presenting a certificate signed by an unknown CA. - When `optional = true`, Traefik authorizes connections from clients presenting a certificate signed by an unknown CA.
```toml ```toml tab="TOML"
[tls.options] [tls.options]
[tls.options.default] [tls.options.default]
[tls.options.default.ClientCA] [tls.options.default.clientCA]
# in PEM format. each file can contain multiple CAs. # in PEM format. each file can contain multiple CAs.
files = ["tests/clientca1.crt", "tests/clientca2.crt"] files = ["tests/clientca1.crt", "tests/clientca2.crt"]
optional = false optional = false
``` ```
```yaml tab="YAML"
tls:
options:
default:
clientCA:
# in PEM format. each file can contain multiple CAs.
files:
- tests/clientca1.crt
- tests/clientca2.crt
optional: false
```
### Cipher Suites ### Cipher Suites
See [cipherSuites](https://godoc.org/crypto/tls#pkg-constants) for more information. See [cipherSuites](https://godoc.org/crypto/tls#pkg-constants) for more information.
```toml ```toml tab="TOML"
[tls.options] [tls.options]
[tls.options.default] [tls.options.default]
cipherSuites = [ cipherSuites = [
@ -124,13 +183,29 @@ See [cipherSuites](https://godoc.org/crypto/tls#pkg-constants) for more informat
] ]
``` ```
```yaml tab="YAML"
tls:
options:
default:
cipherSuites:
- TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256
- TLS_RSA_WITH_AES_256_GCM_SHA384
```
### Strict SNI Checking ### Strict SNI Checking
With strict SNI checking, Traefik won't allow connections from clients connections With strict SNI checking, Traefik won't allow connections from clients connections
that do not specify a server_name extension. that do not specify a server_name extension.
```toml ```toml tab="TOML"
[tls.options] [tls.options]
[tls.options.default] [tls.options.default]
sniStrict = true sniStrict = true
``` ```
```yaml tab="YAML"
tls:
options:
default:
sniStrict: true
```

View file

@ -41,7 +41,7 @@ labels:
```toml tab="File" ```toml tab="File"
# Prefixing with /foo # Prefixing with /foo
[http.middlewares] [http.middlewares]
[http.middlewares.add-foo.AddPrefix] [http.middlewares.add-foo.addPrefix]
prefix = "/foo" prefix = "/foo"
``` ```

View file

@ -47,7 +47,7 @@ labels:
```toml tab="File" ```toml tab="File"
# Declaring the user list # Declaring the user list
[http.middlewares] [http.middlewares]
[http.middlewares.test-auth.basicauth] [http.middlewares.test-auth.basicAuth]
users = [ users = [
"test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/", "test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/",
"test2:$apr1$d9hr9HBB$4HxwgUir3HP4EsggP/QNo0", "test2:$apr1$d9hr9HBB$4HxwgUir3HP4EsggP/QNo0",
@ -120,7 +120,7 @@ spec:
``` ```
```toml tab="File" ```toml tab="File"
[http.middlewares.my-auth.basicauth] [http.middlewares.my-auth.basicAuth]
# ... # ...
headerField = "X-WebAuth-User" headerField = "X-WebAuth-User"
``` ```

View file

@ -117,10 +117,10 @@ labels:
rule = "Host(`mydomain`)" rule = "Host(`mydomain`)"
[http.middlewares] [http.middlewares]
[http.middlewares.secured.Chain] [http.middlewares.secured.chain]
middlewares = ["https-only", "known-ips", "auth-users"] middlewares = ["https-only", "known-ips", "auth-users"]
[http.middlewares.auth-users.BasicAuth] [http.middlewares.auth-users.basicAuth]
users = ["test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/"] users = ["test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/"]
[http.middlewares.https-only.redirectScheme] [http.middlewares.https-only.redirectScheme]
@ -131,7 +131,7 @@ labels:
[http.services] [http.services]
[http.services.service1] [http.services.service1]
[http.services.service1.LoadBalancer] [http.services.service1.loadBalancer]
[[http.services.service1.LoadBalancer.Servers]] [[http.services.service1.loadBalancer.servers]]
URL = "http://127.0.0.1:80" url = "http://127.0.0.1:80"
``` ```

View file

@ -40,7 +40,7 @@ labels:
```toml tab="File" ```toml tab="File"
# Enable gzip compression # Enable gzip compression
[http.middlewares] [http.middlewares]
[http.middlewares.test-compress.Compress] [http.middlewares.test-compress.compress]
``` ```
## Notes ## Notes

View file

@ -53,7 +53,7 @@ labels:
## Configuration Options ## Configuration Options
### `Users` ### `users`
The `users` option is an array of authorized users. Each user will be declared using the `name:realm:encoded-password` format. The `users` option is an array of authorized users. Each user will be declared using the `name:realm:encoded-password` format.
@ -61,7 +61,7 @@ The `users` option is an array of authorized users. Each user will be declared u
If both `users` and `usersFile` are provided, the two are merged. The content of `usersFile` has precedence over `users`. If both `users` and `usersFile` are provided, the two are merged. The content of `usersFile` has precedence over `users`.
### `UsersFile` ### `usersFile`
The `usersFile` option is the path to an external file that contains the authorized users for the middleware. The `usersFile` option is the path to an external file that contains the authorized users for the middleware.
@ -78,11 +78,11 @@ The file content is a list of `name:realm:encoded-password`.
If both `users` and `usersFile` are provided, the two are merged. The content of `usersFile` has precedence over `users`. If both `users` and `usersFile` are provided, the two are merged. The content of `usersFile` has precedence over `users`.
### `Realm` ### `realm`
You can customize the realm for the authentication with the `realm` option. The default value is `traefik`. You can customize the realm for the authentication with the `realm` option. The default value is `traefik`.
### `HeaderField` ### `headerField`
You can customize the header field for the authenticated user using the `headerField`option. You can customize the header field for the authenticated user using the `headerField`option.
@ -121,6 +121,6 @@ labels:
headerField = "X-WebAuth-User" headerField = "X-WebAuth-User"
``` ```
### `RemoveHeader` ### `removeHeader`
Set the `removeHeader` option to `true` to remove the authorization header before forwarding the request to your service. (Default value is `false`.) Set the `removeHeader` option to `true` to remove the authorization header before forwarding the request to your service. (Default value is `false`.)

View file

@ -52,7 +52,7 @@ labels:
```toml tab="File" ```toml tab="File"
# Custom Error Page for 5XX # Custom Error Page for 5XX
[http.middlewares] [http.middlewares]
[http.middlewares.test-errorpage.Errors] [http.middlewares.test-errorpage.errors]
status = ["500-599"] status = ["500-599"]
service = "serviceError" service = "serviceError"
query = "/{status}.html" query = "/{status}.html"

View file

@ -14,14 +14,14 @@ Otherwise, the response from the authentication server is returned.
```yaml tab="Docker" ```yaml tab="Docker"
# Forward authentication to authserver.com # Forward authentication to authserver.com
labels: labels:
- "traefik.http.middlewares.test-auth.ForwardAuth.Address=https://authserver.com/auth" - "traefik.http.middlewares.test-auth.forwardauth.address=https://authserver.com/auth"
- "traefik.http.middlewares.test-auth.ForwardAuth.AuthResponseHeaders=X-Auth-User, X-Secret" - "traefik.http.middlewares.test-auth.forwardauth.authResponseHeaders=X-Auth-User, X-Secret"
- "traefik.http.middlewares.test-auth.ForwardAuth.TLS.CA=path/to/local.crt" - "traefik.http.middlewares.test-auth.forwardauth.tls.ca=path/to/local.crt"
- "traefik.http.middlewares.test-auth.ForwardAuth.TLS.CAOptional=true" - "traefik.http.middlewares.test-auth.forwardauth.tls.caOptional=true"
- "traefik.http.middlewares.test-auth.ForwardAuth.TLS.Cert=path/to/foo.cert" - "traefik.http.middlewares.test-auth.forwardauth.tls.cert=path/to/foo.cert"
- "traefik.http.middlewares.test-auth.ForwardAuth.TLS.InsecureSkipVerify=true" - "traefik.http.middlewares.test-auth.forwardauth.tls.insecureSkipVerify=true"
- "traefik.http.middlewares.test-auth.ForwardAuth.TLS.Key=path/to/foo.key" - "traefik.http.middlewares.test-auth.forwardauth.tls.key=path/to/foo.key"
- "traefik.http.middlewares.test-auth.ForwardAuth.TrustForwardHeader=true" - "traefik.http.middlewares.test-auth.forwardauth.trustForwardHeader=true"
``` ```
```yaml tab="Kubernetes" ```yaml tab="Kubernetes"
@ -45,28 +45,28 @@ spec:
```json tab="Marathon" ```json tab="Marathon"
"labels": { "labels": {
"traefik.http.middlewares.test-auth.ForwardAuth.Address": "https://authserver.com/auth", "traefik.http.middlewares.test-auth.forwardauth.address": "https://authserver.com/auth",
"traefik.http.middlewares.test-auth.ForwardAuth.AuthResponseHeaders": "X-Auth-User,X-Secret", "traefik.http.middlewares.test-auth.forwardauth.authResponseHeaders": "X-Auth-User,X-Secret",
"traefik.http.middlewares.test-auth.ForwardAuth.TLS.CA": "path/to/local.crt", "traefik.http.middlewares.test-auth.forwardauth.tls.ca": "path/to/local.crt",
"traefik.http.middlewares.test-auth.ForwardAuth.TLS.CAOptional": "true", "traefik.http.middlewares.test-auth.forwardauth.tls.caOptional": "true",
"traefik.http.middlewares.test-auth.ForwardAuth.TLS.Cert": "path/to/foo.cert", "traefik.http.middlewares.test-auth.forwardauth.tls.cert": "path/to/foo.cert",
"traefik.http.middlewares.test-auth.ForwardAuth.TLS.InsecureSkipVerify": "true", "traefik.http.middlewares.test-auth.forwardauth.tls.insecureSkipVerify": "true",
"traefik.http.middlewares.test-auth.ForwardAuth.TLS.Key": "path/to/foo.key", "traefik.http.middlewares.test-auth.forwardauth.tls.key": "path/to/foo.key",
"traefik.http.middlewares.test-auth.ForwardAuth.TrustForwardHeader": "true" "traefik.http.middlewares.test-auth.forwardauth.trustForwardHeader": "true"
} }
``` ```
```yaml tab="Rancher" ```yaml tab="Rancher"
# Forward authentication to authserver.com # Forward authentication to authserver.com
labels: labels:
- "traefik.http.middlewares.test-auth.ForwardAuth.Address=https://authserver.com/auth" - "traefik.http.middlewares.test-auth.forwardauth.address=https://authserver.com/auth"
- "traefik.http.middlewares.test-auth.ForwardAuth.AuthResponseHeaders=X-Auth-User, X-Secret" - "traefik.http.middlewares.test-auth.forwardauth.authResponseHeaders=X-Auth-User, X-Secret"
- "traefik.http.middlewares.test-auth.ForwardAuth.TLS.CA=path/to/local.crt" - "traefik.http.middlewares.test-auth.forwardauth.tls.ca=path/to/local.crt"
- "traefik.http.middlewares.test-auth.ForwardAuth.TLS.CAOptional=true" - "traefik.http.middlewares.test-auth.forwardauth.tls.caOptional=true"
- "traefik.http.middlewares.test-auth.ForwardAuth.TLS.Cert=path/to/foo.cert" - "traefik.http.middlewares.test-auth.forwardauth.tls.cert=path/to/foo.cert"
- "traefik.http.middlewares.test-auth.ForwardAuth.TLS.InsecureSkipVerify=true" - "traefik.http.middlewares.test-auth.forwardauth.tls.InisecureSkipVerify=true"
- "traefik.http.middlewares.test-auth.ForwardAuth.TLS.Key=path/to/foo.key" - "traefik.http.middlewares.test-auth.forwardauth.tls.key=path/to/foo.key"
- "traefik.http.middlewares.test-auth.ForwardAuth.TrustForwardHeader=true" - "traefik.http.middlewares.test-auth.forwardauth.trustForwardHeader=true"
``` ```
```toml tab="File" ```toml tab="File"
@ -77,7 +77,7 @@ labels:
trustForwardHeader = true trustForwardHeader = true
authResponseHeaders = ["X-Auth-User", "X-Secret"] authResponseHeaders = ["X-Auth-User", "X-Secret"]
[http.middlewares.test-auth.forwardauth.tls] [http.middlewares.test-auth.forwardAuth.tls]
ca = "path/to/local.crt" ca = "path/to/local.crt"
caOptional = true caOptional = true
cert = "path/to/foo.cert" cert = "path/to/foo.cert"
@ -92,7 +92,7 @@ The `address` option defines the authentication server address.
### `trustForwardHeader` ### `trustForwardHeader`
Set the `trustForwardHeader` option to true to trust all the existing X-Forwarded-* headers. Set the `trustForwardHeader` option to `true` to trust all the existing `X-Forwarded-*` headers.
### `authResponseHeaders` ### `authResponseHeaders`
@ -100,4 +100,4 @@ The `authResponseHeaders` option is the list of the headers to copy from the aut
### `tls` ### `tls`
The `tls` option is the tls configuration from Traefik to the authentication server. The `tls` option is the TLS configuration from Traefik to the authentication server.

View file

@ -15,8 +15,8 @@ Add the `X-Script-Name` header to the proxied request and the `X-Custom-Response
```yaml tab="Docker" ```yaml tab="Docker"
labels: labels:
- "traefik.http.middlewares.testHeader.Headers.CustomRequestHeaders.X-Script-Name=test" - "traefik.http.middlewares.testHeader.headers.customrequestheaders.X-Script-Name=test"
- "traefik.http.middlewares.testHeader.Headers.CustomResponseHeaders.X-Custom-Response-Header=True" - "traefik.http.middlewares.testHeader.headers.customresponseheaders.X-Custom-Response-Header=True"
``` ```
```yaml tab="Kubernetes" ```yaml tab="Kubernetes"
@ -34,23 +34,23 @@ spec:
```json tab="Marathon" ```json tab="Marathon"
"labels": { "labels": {
"traefik.http.middlewares.testHeader.Headers.CustomRequestHeaders.X-Script-Name": "test", "traefik.http.middlewares.testheader.headers.customrequestheaders.X-Script-Name": "test",
"traefik.http.middlewares.testHeader.Headers.CustomResponseHeaders.X-Custom-Response-Header": "True" "traefik.http.middlewares.testheader.headers.customresponseheaders.X-Custom-Response-Header": "True"
} }
``` ```
```yaml tab="Rancher" ```yaml tab="Rancher"
labels: labels:
- "traefik.http.middlewares.testHeader.Headers.CustomRequestHeaders.X-Script-Name=test" - "traefik.http.middlewares.testheader.headers.customrequestheaders.X-Script-Name=test"
- "traefik.http.middlewares.testHeader.Headers.CustomResponseHeaders.X-Custom-Response-Header=True" - "traefik.http.middlewares.testheader.headers.customresponseheaders.X-Custom-Response-Header=True"
``` ```
```toml tab="File" ```toml tab="File"
[http.middlewares] [http.middlewares]
[http.middlewares.testHeader.headers] [http.middlewares.testHeader.headers]
[http.middlewares.testHeader.headers.CustomRequestHeaders] [http.middlewares.testHeader.headers.customRequestHeaders]
X-Script-Name = "test" X-Script-Name = "test"
[http.middlewares.testHeader.headers.CustomResponseHeaders] [http.middlewares.testHeader.headers.customResponseHeaders]
X-Custom-Response-Header = "True" X-Custom-Response-Header = "True"
``` ```
@ -77,22 +77,22 @@ spec:
```yaml tab="Rancher" ```yaml tab="Rancher"
labels: labels:
- "traefik.http.middlewares.testHeader.Headers.CustomRequestHeaders.X-Script-Name=test" - "traefik.http.middlewares.testheader.headers.customrequestheaders.X-Script-Name=test"
``` ```
```json tab="Marathon" ```json tab="Marathon"
"labels": { "labels": {
"traefik.http.middlewares.testHeader.Headers.CustomRequestHeaders.X-Script-Name": "test", "traefik.http.middlewares.testheader.headers.customrequestheaders.X-Script-Name": "test",
} }
``` ```
```toml tab="File" ```toml tab="File"
[http.middlewares] [http.middlewares]
[http.middlewares.testHeader.headers] [http.middlewares.testHeader.headers]
[http.middlewares.testHeader.headers.CustomRequestHeaders] [http.middlewares.testHeader.headers.customRequestHeaders]
X-Script-Name = "test" # Adds X-Script-Name = "test" # Adds
X-Custom-Request-Header = "" # Removes X-Custom-Request-Header = "" # Removes
[http.middlewares.testHeader.headers.CustomResponseHeaders] [http.middlewares.testHeader.headers.customResponseHeaders]
X-Custom-Response-Header = "" # Removes X-Custom-Response-Header = "" # Removes
``` ```
@ -103,8 +103,8 @@ This functionality allows for some easy security features to quickly be set.
```yaml tab="Docker" ```yaml tab="Docker"
labels: labels:
- "traefik.http.middlewares.testHeader.Headers.FrameDeny=true" - "traefik.http.middlewares.testHeader.headers.framedeny=true"
- "traefik.http.middlewares.testHeader.Headers.SSLRedirect=true" - "traefik.http.middlewares.testHeader.headers.sslredirect=true"
``` ```
```yaml tab="Kubernetes" ```yaml tab="Kubernetes"
@ -120,14 +120,14 @@ spec:
```yaml tab="Rancher" ```yaml tab="Rancher"
labels: labels:
- "traefik.http.middlewares.testHeader.Headers.FrameDeny=true" - "traefik.http.middlewares.testheader.headers.framedeny=true"
- "traefik.http.middlewares.testHeader.Headers.SSLRedirect=true" - "traefik.http.middlewares.testheader.headers.sslredirect=true"
``` ```
```json tab="Marathon" ```json tab="Marathon"
"labels": { "labels": {
"traefik.http.middlewares.testHeader.Headers.FrameDeny": "true", "traefik.http.middlewares.testheader.headers.framedeny": "true",
"traefik.http.middlewares.testHeader.Headers.SSLRedirect": "true" "traefik.http.middlewares.testheader.headers.sslredirect": "true"
} }
``` ```
@ -145,10 +145,10 @@ This functionality allows for more advanced security features to quickly be set.
```yaml tab="Docker" ```yaml tab="Docker"
labels: labels:
- "traefik.http.middlewares.testHeader.Headers.AccessControlAllowMethods=GET,OPTIONS,PUT" - "traefik.http.middlewares.testheader.headers.accesscontrolallowmethods=GET,OPTIONS,PUT"
- "traefik.http.middlewares.testHeader.Headers.AccessControlAllowOrigin=origin-list-or-null" - "traefik.http.middlewares.testheader.headers.accesscontrolalloworigin=origin-list-or-null"
- "traefik.http.middlewares.testHeader.Headers.AccessControlMaxAge=100" - "traefik.http.middlewares.testheader.headers.accesscontrolmaxage=100"
- "traefik.http.middlewares.testHeader.Headers.AddVaryHeader=true" - "traefik.http.middlewares.testheader.headers.addvaryheader=true"
``` ```
```yaml tab="Kubernetes" ```yaml tab="Kubernetes"
@ -158,39 +158,39 @@ metadata:
name: testHeader name: testHeader
spec: spec:
headers: headers:
AccessControlAllowMethods: accessControlAllowMethods:
- "GET" - "GET"
- "OPTIONS" - "OPTIONS"
- "PUT" - "PUT"
AccessControlAllowOrigin: "origin-list-or-null" accessControlAllowOrigin: "origin-list-or-null"
AccessControlMaxAge: 100 accessControlMaxAge: 100
AddVaryHeader: "true" addVaryHeader: "true"
``` ```
```yaml tab="Rancher" ```yaml tab="Rancher"
labels: labels:
- "traefik.http.middlewares.testHeader.Headers.AccessControlAllowMethods=GET,OPTIONS,PUT" - "traefik.http.middlewares.testheader.headers.accesscontrolallowmethods=GET,OPTIONS,PUT"
- "traefik.http.middlewares.testHeader.Headers.AccessControlAllowOrigin=origin-list-or-null" - "traefik.http.middlewares.testheader.headers.accesscontrolalloworigin=origin-list-or-null"
- "traefik.http.middlewares.testHeader.Headers.AccessControlMaxAge=100" - "traefik.http.middlewares.testheader.headers.accesscontrolmaxage=100"
- "traefik.http.middlewares.testHeader.Headers.AddVaryHeader=true" - "traefik.http.middlewares.testheader.headers.addvaryheader=true"
``` ```
```json tab="Marathon" ```json tab="Marathon"
"labels": { "labels": {
"traefik.http.middlewares.testHeader.Headers.AccessControlAllowMethods": "GET,OPTIONS,PUT", "traefik.http.middlewares.testheader.headers.accesscontrolallowmethods": "GET,OPTIONS,PUT",
"traefik.http.middlewares.testHeader.Headers.AccessControlAllowOrigin": "origin-list-or-null", "traefik.http.middlewares.testheader.headers.accesscontrolalloworigin": "origin-list-or-null",
"traefik.http.middlewares.testHeader.Headers.AccessControlMaxAge": "100", "traefik.http.middlewares.testheader.headers.accesscontrolmaxage": "100",
"traefik.http.middlewares.testHeader.Headers.AddVaryHeader": "true" "traefik.http.middlewares.testheader.headers.addvaryheader": "true"
} }
``` ```
```toml tab="File" ```toml tab="File"
[http.middlewares] [http.middlewares]
[http.middlewares.testHeader.headers] [http.middlewares.testHeader.headers]
AccessControlAllowMethods= ["GET", "OPTIONS", "PUT"] accessControlAllowMethods= ["GET", "OPTIONS", "PUT"]
AccessControlAllowOrigin = "origin-list-or-null" accessControlAllowOrigin = "origin-list-or-null"
AccessControlMaxAge = 100 accessControlMaxAge = 100
AddVaryHeader = true addVaryHeader = true
``` ```
## Configuration Options ## Configuration Options
@ -225,7 +225,8 @@ The `accessControlAllowMethods` indicates which methods can be used during requ
### `accessControlAllowOrigin` ### `accessControlAllowOrigin`
The `accessControlAllowOrigin` indicates whether a resource can be shared by returning different values. The three options for this value are: The `accessControlAllowOrigin` indicates whether a resource can be shared by returning different values.
The three options for this value are:
- `origin-list-or-null` - `origin-list-or-null`
- `*` - `*`
@ -261,11 +262,12 @@ Set the `sslTemporaryRedirect` to `true` to force an SSL redirection using a 302
### `sslHost` ### `sslHost`
The `SSLHost` option is the host name that is used to redirect http requests to https. The `sslHost` option is the host name that is used to redirect http requests to https.
### `sslProxyHeaders` ### `sslProxyHeaders`
The `sslProxyHeaders` option is set of header keys with associated values that would indicate a valid https request. Useful when using other proxies with header like: `"X-Forwarded-Proto": "https"`. The `sslProxyHeaders` option is set of header keys with associated values that would indicate a valid https request.
Useful when using other proxies with header like: `"X-Forwarded-Proto": "https"`.
### `sslForceHost` ### `sslForceHost`
@ -273,7 +275,8 @@ Set `sslForceHost` to true and set SSLHost to forced requests to use `SSLHost` e
### `stsSeconds` ### `stsSeconds`
The `stsSeconds` is the max-age of the Strict-Transport-Security header. If set to 0, would NOT include the header. The `stsSeconds` is the max-age of the Strict-Transport-Security header.
If set to 0, would NOT include the header.
### `stsIncludeSubdomains` ### `stsIncludeSubdomains`
@ -281,11 +284,11 @@ The `stsIncludeSubdomains` is set to true, the `includeSubdomains` will be appen
### `stsPreload` ### `stsPreload`
Set `STSPreload` to true to have the `preload` flag appended to the Strict-Transport-Security header. Set `stsPreload` to true to have the `preload` flag appended to the Strict-Transport-Security header.
### `forceSTSHeader` ### `forceSTSHeader`
Set `ForceSTSHeader` to true, to add the STS header even when the connection is HTTP. Set `forceSTSHeader` to true, to add the STS header even when the connection is HTTP.
### `frameDeny` ### `frameDeny`
@ -293,7 +296,8 @@ Set `frameDeny` to true to add the `X-Frame-Options` header with the value of `D
### `customFrameOptionsValue` ### `customFrameOptionsValue`
The `customFrameOptionsValue` allows the `X-Frame-Options` header value to be set with a custom value. This overrides the FrameDeny option. The `customFrameOptionsValue` allows the `X-Frame-Options` header value to be set with a custom value.
This overrides the FrameDeny option.
### `contentTypeNosniff` ### `contentTypeNosniff`
@ -301,11 +305,12 @@ Set `contentTypeNosniff` to true to add the `X-Content-Type-Options` header with
### `browserXssFilter` ### `browserXssFilter`
Set `BrowserXssFilter` to true to add the `X-XSS-Protection` header with the value `1; mode=block`. Set `browserXssFilter` to true to add the `X-XSS-Protection` header with the value `1; mode=block`.
### `customBrowserXSSValue` ### `customBrowserXSSValue`
The `customBrowserXssValue` option allows the `X-XSS-Protection` header value to be set with a custom value. This overrides the BrowserXssFilter option. The `customBrowserXssValue` option allows the `X-XSS-Protection` header value to be set with a custom value.
This overrides the BrowserXssFilter option.
### `contentSecurityPolicy` ### `contentSecurityPolicy`
@ -321,5 +326,7 @@ The `referrerPolicy` allows sites to control when browsers will pass the Referer
### `isDevelopment` ### `isDevelopment`
Set `isDevelopment` to true when developing. The AllowedHosts, SSL, and STS options can cause some unwanted effects. Usually testing happens on http, not https, and on localhost, not your production domain. Set `isDevelopment` to true when developing.
The AllowedHosts, SSL, and STS options can cause some unwanted effects.
Usually testing happens on http, not https, and on localhost, not your production domain.
If you would like your development environment to mimic production with complete Host blocking, SSL redirects, and STS headers, leave this as false. If you would like your development environment to mimic production with complete Host blocking, SSL redirects, and STS headers, leave this as false.

View file

@ -12,7 +12,7 @@ IPWhitelist accepts / refuses requests based on the client IP.
```yaml tab="Docker" ```yaml tab="Docker"
# Accepts request from defined IP # Accepts request from defined IP
labels: labels:
- "traefik.http.middlewares.test-ipwhitelist.IPWhiteList.SourceRange=127.0.0.1/32, 192.168.1.7" - "traefik.http.middlewares.test-ipwhitelist.ipwhitelist.sourcerange=127.0.0.1/32, 192.168.1.7"
``` ```
```yaml tab="Kubernetes" ```yaml tab="Kubernetes"
@ -29,14 +29,14 @@ spec:
```json tab="Marathon" ```json tab="Marathon"
"labels": { "labels": {
"traefik.http.middlewares.test-ipwhitelist.IPWhiteList.SourceRange": "127.0.0.1/32,192.168.1.7" "traefik.http.middlewares.test-ipwhitelist.ipwhitelist.sourcerange": "127.0.0.1/32,192.168.1.7"
} }
``` ```
```yaml tab="Rancher" ```yaml tab="Rancher"
# Accepts request from defined IP # Accepts request from defined IP
labels: labels:
- "traefik.http.middlewares.test-ipwhitelist.IPWhiteList.SourceRange=127.0.0.1/32, 192.168.1.7" - "traefik.http.middlewares.test-ipwhitelist.ipwhitelist.sourcerange=127.0.0.1/32, 192.168.1.7"
``` ```
```toml tab="File" ```toml tab="File"
@ -75,7 +75,7 @@ The `depth` option tells Traefik to use the `X-Forwarded-For` header and take th
```yaml tab="Docker" ```yaml tab="Docker"
# Whitelisting Based on `X-Forwarded-For` with `depth=2` # Whitelisting Based on `X-Forwarded-For` with `depth=2`
labels: labels:
- "traefik.http.middlewares.testIPwhitelist.ipWhiteList.SourceRange=127.0.0.1/32, 192.168.1.7" - "traefik.http.middlewares.testIPwhitelist.ipwhitelist.sourcerange=127.0.0.1/32, 192.168.1.7"
- "traefik.http.middlewares.testIPwhitelist.ipwhitelist.ipstrategy.depth=2" - "traefik.http.middlewares.testIPwhitelist.ipwhitelist.ipstrategy.depth=2"
``` ```
@ -87,23 +87,23 @@ The `depth` option tells Traefik to use the `X-Forwarded-For` header and take th
name: testIPwhitelist name: testIPwhitelist
spec: spec:
ipWhiteList: ipWhiteList:
SourceRange: sourceRange:
- 127.0.0.1/32 - 127.0.0.1/32
- 192.168.1.7 - 192.168.1.7
ipstrategy: ipStrategy:
depth: 2 depth: 2
``` ```
```yaml tab="Rancher" ```yaml tab="Rancher"
# Whitelisting Based on `X-Forwarded-For` with `depth=2` # Whitelisting Based on `X-Forwarded-For` with `depth=2`
labels: labels:
- "traefik.http.middlewares.testIPwhitelist.ipWhiteList.SourceRange=127.0.0.1/32, 192.168.1.7" - "traefik.http.middlewares.testIPwhitelist.ipwhitelist.sourcerange=127.0.0.1/32, 192.168.1.7"
- "traefik.http.middlewares.testIPwhitelist.ipwhitelist.ipstrategy.depth=2" - "traefik.http.middlewares.testIPwhitelist.ipwhitelist.ipstrategy.depth=2"
``` ```
```json tab="Marathon" ```json tab="Marathon"
"labels": { "labels": {
"traefik.http.middlewares.testIPwhitelist.ipWhiteList.SourceRange": "127.0.0.1/32, 192.168.1.7", "traefik.http.middlewares.testIPwhitelist.ipwhitelist.sourcerange": "127.0.0.1/32, 192.168.1.7",
"traefik.http.middlewares.testIPwhitelist.ipwhitelist.ipstrategy.depth": "2" "traefik.http.middlewares.testIPwhitelist.ipwhitelist.ipstrategy.depth": "2"
} }
``` ```
@ -142,7 +142,7 @@ The `depth` option tells Traefik to use the `X-Forwarded-For` header and take th
```yaml tab="Docker" ```yaml tab="Docker"
# Exclude from `X-Forwarded-For` # Exclude from `X-Forwarded-For`
labels: labels:
- "traefik.http.middlewares.test-ipwhitelist.ipwhitelist.ipstrategy.excludedIPs=127.0.0.1/32, 192.168.1.7" - "traefik.http.middlewares.test-ipwhitelist.ipwhitelist.ipstrategy.excludedips=127.0.0.1/32, 192.168.1.7"
``` ```
```yaml tab="Kubernetes" ```yaml tab="Kubernetes"
@ -153,7 +153,7 @@ metadata:
name: test-ipwhitelist name: test-ipwhitelist
spec: spec:
ipWhiteList: ipWhiteList:
ipstrategy: ipStrategy:
excludedIPs: excludedIPs:
- 127.0.0.1/32 - 127.0.0.1/32
- 192.168.1.7 - 192.168.1.7
@ -162,12 +162,12 @@ spec:
```yaml tab="Rancher" ```yaml tab="Rancher"
# Exclude from `X-Forwarded-For` # Exclude from `X-Forwarded-For`
labels: labels:
- "traefik.http.middlewares.test-ipwhitelist.ipwhitelist.ipstrategy.excludedIPs=127.0.0.1/32, 192.168.1.7" - "traefik.http.middlewares.test-ipwhitelist.ipwhitelist.ipstrategy.excludedips=127.0.0.1/32, 192.168.1.7"
``` ```
```json tab="Marathon" ```json tab="Marathon"
"labels": { "labels": {
"traefik.http.middlewares.test-ipwhitelist.ipwhitelist.ipstrategy.excludedIPs": "127.0.0.1/32, 192.168.1.7" "traefik.http.middlewares.test-ipwhitelist.ipwhitelist.ipstrategy.excludedips": "127.0.0.1/32, 192.168.1.7"
} }
``` ```

View file

@ -40,7 +40,7 @@ labels:
```toml tab="File" ```toml tab="File"
# Limiting to 10 simultaneous connections # Limiting to 10 simultaneous connections
[http.middlewares] [http.middlewares]
[http.middlewares.test-maxconn.maxconn] [http.middlewares.test-maxconn.maxConn]
amount = 10 amount = 10
``` ```

View file

@ -22,7 +22,7 @@ whoami:
# Create a middleware named `foo-add-prefix` # Create a middleware named `foo-add-prefix`
- "traefik.http.middlewares.foo-add-prefix.addprefix.prefix=/foo" - "traefik.http.middlewares.foo-add-prefix.addprefix.prefix=/foo"
# Apply the middleware named `foo-add-prefix` to the router named `router1` # Apply the middleware named `foo-add-prefix` to the router named `router1`
- "traefik.http.router.router1.Middlewares=foo-add-prefix@docker" - "traefik.http.router.router1.middlewares=foo-add-prefix@docker"
``` ```
```yaml tab="Kubernetes" ```yaml tab="Kubernetes"
@ -46,7 +46,7 @@ kind: Middleware
metadata: metadata:
name: stripprefix name: stripprefix
spec: spec:
stripprefix: stripPrefix:
prefixes: prefixes:
- /stripit - /stripit
@ -66,7 +66,7 @@ spec:
```json tab="Marathon" ```json tab="Marathon"
"labels": { "labels": {
"traefik.http.middlewares.foo-add-prefix.addprefix.prefix": "/foo", "traefik.http.middlewares.foo-add-prefix.addprefix.prefix": "/foo",
"traefik.http.router.router1.Middlewares": "foo-add-prefix@marathon" "traefik.http.router.router1.middlewares": "foo-add-prefix@marathon"
} }
``` ```
@ -76,7 +76,7 @@ labels:
# Create a middleware named `foo-add-prefix` # Create a middleware named `foo-add-prefix`
- "traefik.http.middlewares.foo-add-prefix.addprefix.prefix=/foo" - "traefik.http.middlewares.foo-add-prefix.addprefix.prefix=/foo"
# Apply the middleware named `foo-add-prefix` to the router named `router1` # Apply the middleware named `foo-add-prefix` to the router named `router1`
- "traefik.http.router.router1.Middlewares=foo-add-prefix@rancher" - "traefik.http.router.router1.middlewares=foo-add-prefix@rancher"
``` ```
```toml tab="File" ```toml tab="File"
@ -86,20 +86,20 @@ labels:
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
Service = "myService" service = "myService"
Middlewares = ["foo-add-prefix"] middlewares = ["foo-add-prefix"]
Rule = "Host(`example.com`)" rule = "Host(`example.com`)"
[http.middlewares] [http.middlewares]
[http.middlewares.foo-add-prefix.AddPrefix] [http.middlewares.foo-add-prefix.addPrefix]
prefix = "/foo" prefix = "/foo"
[http.services] [http.services]
[http.services.service1] [http.services.service1]
[http.services.service1.LoadBalancer] [http.services.service1.loadBalancer]
[[http.services.service1.LoadBalancer.Servers]] [[http.services.service1.loadBalancer.servers]]
URL = "http://127.0.0.1:80" url = "http://127.0.0.1:80"
``` ```
## Provider Namespace ## Provider Namespace
@ -132,7 +132,7 @@ and therefore this specification would be ignored even if present.
[providers.file] [providers.file]
[http.middlewares] [http.middlewares]
[http.middlewares.add-foo-prefix.AddPrefix] [http.middlewares.add-foo-prefix.addPrefix]
prefix = "/foo" prefix = "/foo"
``` ```

View file

@ -23,7 +23,7 @@ kind: Middleware
metadata: metadata:
name: addprefix name: addprefix
spec: spec:
passtlsclientcert: passTLSClientCert:
pem: true pem: true
``` ```
@ -42,7 +42,7 @@ labels:
```toml tab="File" ```toml tab="File"
# Pass the escaped pem in the `X-Forwarded-Tls-Client-Cert` header. # Pass the escaped pem in the `X-Forwarded-Tls-Client-Cert` header.
[http.middlewares] [http.middlewares]
[http.middlewares.test-passtlsclientcert.passtlsclientcert] [http.middlewares.test-passtlsclientcert.passTLSClientCert]
pem = true pem = true
``` ```
@ -77,7 +77,7 @@ labels:
metadata: metadata:
name: test-passtlsclientcert name: test-passtlsclientcert
spec: spec:
passtlsclientcert: passTLSClientCert:
info: info:
notAfter: true notAfter: true
notBefore: true notBefore: true
@ -147,12 +147,12 @@ labels:
```toml tab="File" ```toml tab="File"
# Pass all the available info in the `X-Forwarded-Tls-Client-Cert-Info` header # Pass all the available info in the `X-Forwarded-Tls-Client-Cert-Info` header
[http.middlewares] [http.middlewares]
[http.middlewares.test-passtlsclientcert.passtlsclientcert] [http.middlewares.test-passtlsclientcert.passTLSClientCert]
[http.middlewares.test-passtlsclientcert.passtlsclientcert.info] [http.middlewares.test-passtlsclientcert.passTLSClientCert.info]
notAfter = true notAfter = true
notBefore = true notBefore = true
sans = true sans = true
[http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject] [http.middlewares.test-passtlsclientcert.passTLSClientCert.info.subject]
country = true country = true
province = true province = true
locality = true locality = true
@ -160,7 +160,7 @@ labels:
commonName = true commonName = true
serialNumber = true serialNumber = true
domainComponent = true domainComponent = true
[http.middlewares.test-passtlsclientcert.passtlsclientcert.info.issuer] [http.middlewares.test-passtlsclientcert.passTLSClientCert.info.issuer]
country = true country = true
province = true province = true
locality = true locality = true
@ -360,9 +360,9 @@ Subject="DC=org,DC=cheese,C=FR,C=US,ST=Cheese org state,ST=Cheese com state,L=TO
If there are more than one certificate, they are separated by a `;`. If there are more than one certificate, they are separated by a `;`.
#### `info.notafter` #### `info.notAfter`
Set the `info.notafter` option to `true` to add the `Not After` information from the `Validity` part. Set the `info.notAfter` option to `true` to add the `Not After` information from the `Validity` part.
The data are taken from the following certificate part: The data are taken from the following certificate part:
@ -371,15 +371,15 @@ The data are taken from the following certificate part:
Not After : Dec 5 11:10:16 2020 GMT Not After : Dec 5 11:10:16 2020 GMT
``` ```
The escape `notafter` info part will be like: The escape `notAfter` info part will be like:
```text ```text
NA=1607166616 NA=1607166616
``` ```
#### `info.notbefore` #### `info.notBefore`
Set the `info.notafter` option to `true` to add the `Not Before` information from the `Validity` part. Set the `info.notBefore` option to `true` to add the `Not Before` information from the `Validity` part.
The data are taken from the following certificate part: The data are taken from the following certificate part:
@ -388,7 +388,7 @@ Validity
Not Before: Dec 6 11:10:16 2018 GMT Not Before: Dec 6 11:10:16 2018 GMT
``` ```
The escape `notafter` info part will be like: The escape `notBefore` info part will be like:
```text ```text
NB=1544094616 NB=1544094616
@ -471,9 +471,9 @@ The escape organization info in the subject part will be like :
O=Cheese,O=Cheese 2 O=Cheese,O=Cheese 2
``` ```
##### `info.subject.commonname` ##### `info.subject.commonName`
Set the `info.subject.commonname` option to true to add the `commonname` information into the subject. Set the `info.subject.commonName` option to true to add the `commonName` information into the subject.
The data are taken from the subject part with the `CN` key. The data are taken from the subject part with the `CN` key.
@ -483,9 +483,9 @@ The escape common name info in the subject part will be like :
CN=*.cheese.com CN=*.cheese.com
``` ```
##### `info.subject.serialnumber` ##### `info.subject.serialNumber`
Set the `info.subject.serialnumber` option to true to add the `serialnumber` information into the subject. Set the `info.subject.serialNumber` option to true to add the `serialNumber` information into the subject.
The data are taken from the subject part with the `SN` key. The data are taken from the subject part with the `SN` key.
@ -495,9 +495,9 @@ The escape serial number info in the subject part will be like :
SN=1234567890 SN=1234567890
``` ```
##### `info.subject.domaincomponent` ##### `info.subject.domainComponent`
Set the `info.subject.domaincomponent` option to true to add the `domaincomponent` information into the subject. Set the `info.subject.domainComponent` option to true to add the `domainComponent` information into the subject.
The data are taken from the subject part with the `DC` key. The data are taken from the subject part with the `DC` key.
@ -563,9 +563,9 @@ The escape organization info in the issuer part will be like :
O=Cheese,O=Cheese 2 O=Cheese,O=Cheese 2
``` ```
##### `info.issuer.commonname` ##### `info.issuer.commonName`
Set the `info.issuer.commonname` option to true to add the `commonname` information into the issuer. Set the `info.issuer.commonName` option to true to add the `commonName` information into the issuer.
The data are taken from the issuer part with the `CN` key. The data are taken from the issuer part with the `CN` key.
@ -575,9 +575,9 @@ The escape common name info in the issuer part will be like :
CN=Simple Signing CA 2 CN=Simple Signing CA 2
``` ```
##### `info.issuer.serialnumber` ##### `info.issuer.serialNumber`
Set the `info.issuer.serialnumber` option to true to add the `serialnumber` information into the issuer. Set the `info.issuer.serialNumber` option to true to add the `serialNumber` information into the issuer.
The data are taken from the issuer part with the `SN` key. The data are taken from the issuer part with the `SN` key.
@ -587,9 +587,9 @@ The escape serial number info in the issuer part will be like :
SN=1234567890 SN=1234567890
``` ```
##### `info.issuer.domaincomponent` ##### `info.issuer.domainComponent`
Set the `info.issuer.domaincomponent` option to true to add the `domaincomponent` information into the issuer. Set the `info.issuer.domainComponent` option to true to add the `domainComponent` information into the issuer.
The data are taken from the issuer part with the `DC` key. The data are taken from the issuer part with the `DC` key.

View file

@ -33,7 +33,7 @@ metadata:
spec: spec:
rateLimit: rateLimit:
extractorFunc: client.ip extractorFunc: client.ip
rateset: rateSet:
rate0: rate0:
period: 10s period: 10s
average: 100 average: 100
@ -74,15 +74,15 @@ labels:
# Here, an average of 5 requests every 3 seconds is allowed and an average of 100 requests every 10 seconds. # Here, an average of 5 requests every 3 seconds is allowed and an average of 100 requests every 10 seconds.
# These can "burst" up to 10 and 200 in each period, respectively. # These can "burst" up to 10 and 200 in each period, respectively.
[http.middlewares] [http.middlewares]
[http.middlewares.test-ratelimit.ratelimit] [http.middlewares.test-ratelimit.rateLimit]
extractorfunc = "client.ip" extractorfunc = "client.ip"
[http.middlewares.test-ratelimit.ratelimit.rateset.rate0] [http.middlewares.test-ratelimit.rateLimit.rateSet.rate0]
period = "10s" period = "10s"
average = 100 average = 100
burst = 200 burst = 200
[http.middlewares.test-ratelimit.ratelimit.rateset.rate1] [http.middlewares.test-ratelimit.rateLimit.rateSet.rate1]
period = "3s" period = "3s"
average = 5 average = 5
burst = 10 burst = 10
@ -100,7 +100,7 @@ The possible values are:
- `client.ip` categorizes requests based on the client ip. - `client.ip` categorizes requests based on the client ip.
- `request.header.ANY_HEADER` categorizes requests based on the provided `ANY_HEADER` value. - `request.header.ANY_HEADER` categorizes requests based on the provided `ANY_HEADER` value.
### `ratelimit` ### `rateSet`
You can combine multiple rate limits. You can combine multiple rate limits.
The rate limit will trigger with the first reached limit. The rate limit will trigger with the first reached limit.

View file

@ -45,7 +45,7 @@ labels:
```toml tab="File" ```toml tab="File"
# Redirect with domain replacement # Redirect with domain replacement
[http.middlewares] [http.middlewares]
[http.middlewares.test-redirectregex.redirectregex] [http.middlewares.test-redirectregex.redirectRegex]
regex = "^http://localhost/(.*)" regex = "^http://localhost/(.*)"
replacement = "http://mydomain/$1" replacement = "http://mydomain/$1"
``` ```
@ -58,7 +58,7 @@ Set the `permanent` option to `true` to apply a permanent redirection.
### `regex` ### `regex`
The `Regex` option is the regular expression to match and capture elements from the request URL. The `regex` option is the regular expression to match and capture elements from the request URL.
!!! warning !!! warning

View file

@ -41,7 +41,7 @@ labels:
```toml tab="File" ```toml tab="File"
# Redirect to https # Redirect to https
[http.middlewares] [http.middlewares]
[http.middlewares.test-redirectscheme.redirectscheme] [http.middlewares.test-redirectscheme.redirectScheme]
scheme = "https" scheme = "https"
``` ```

View file

@ -41,7 +41,7 @@ labels:
```toml tab="File" ```toml tab="File"
# Replace the path by /foo # Replace the path by /foo
[http.middlewares] [http.middlewares]
[http.middlewares.test-replacepath.ReplacePath] [http.middlewares.test-replacepath.replacePath]
path = "/foo" path = "/foo"
``` ```

View file

@ -61,7 +61,7 @@ The ReplacePathRegex middleware will:
### `regex` ### `regex`
The `Regex` option is the regular expression to match and capture the path from the request URL. The `regex` option is the regular expression to match and capture the path from the request URL.
!!! warning !!! warning

View file

@ -41,7 +41,7 @@ labels:
```toml tab="File" ```toml tab="File"
# Retry to send request 4 times # Retry to send request 4 times
[http.middlewares] [http.middlewares]
[http.middlewares.test-retry.Retry] [http.middlewares.test-retry.retry]
attempts = 4 attempts = 4
``` ```

View file

@ -43,7 +43,7 @@ labels:
```toml tab="File" ```toml tab="File"
# Strip prefix /foobar and /fiibar # Strip prefix /foobar and /fiibar
[http.middlewares] [http.middlewares]
[http.middlewares.test-stripprefix.StripPrefix] [http.middlewares.test-stripprefix.stripPrefix]
prefixes = ["/foobar", "/fiibar"] prefixes = ["/foobar", "/fiibar"]
``` ```

View file

@ -41,7 +41,7 @@ labels:
```toml tab="File" ```toml tab="File"
# Replace the path by /foo # Replace the path by /foo
[http.middlewares] [http.middlewares]
[http.middlewares.test-stripprefixregex.StripPrefixRegex] [http.middlewares.test-stripprefixregex.stripPrefixRegex]
regex: "^/foo/(.*)" regex: "^/foo/(.*)"
``` ```
@ -56,7 +56,7 @@ The StripPrefixRegex middleware will:
!!! tip !!! tip
Use a `StripPrefixRegex` middleware if your backend listens on the root path (`/`) but should be routeable on a specific prefix. Use a `stripPrefixRegex` middleware if your backend listens on the root path (`/`) but should be routeable on a specific prefix.
### `regex` ### `regex`

View file

@ -4,7 +4,7 @@ To enable the DataDog:
```toml tab="File" ```toml tab="File"
[tracing] [tracing]
[tracing.datadog] [tracing.dataDog]
``` ```
```bash tab="CLI" ```bash tab="CLI"
@ -20,7 +20,7 @@ Local Agent Host Port instructs reporter to send spans to datadog-tracing-agent
```toml tab="File" ```toml tab="File"
[tracing] [tracing]
[tracing.datadog] [tracing.dataDog]
localAgentHostPort = "127.0.0.1:8126" localAgentHostPort = "127.0.0.1:8126"
``` ```
@ -37,7 +37,7 @@ Enable DataDog debug.
```toml tab="File" ```toml tab="File"
[tracing] [tracing]
[tracing.datadog] [tracing.dataDog]
debug = true debug = true
``` ```
@ -54,7 +54,7 @@ Apply shared tag in a form of Key:Value to all the traces.
```toml tab="File" ```toml tab="File"
[tracing] [tracing]
[tracing.datadog] [tracing.dataDog]
globalTag = "sample" globalTag = "sample"
``` ```
@ -72,7 +72,7 @@ this option must be enabled in order to get all the parts of a distributed trace
```toml tab="File" ```toml tab="File"
[tracing] [tracing]
[tracing.datadog] [tracing.dataDog]
prioritySampling = true prioritySampling = true
``` ```

View file

@ -160,7 +160,7 @@ To restrict access to the API handler, one can add authentication with the [basi
```toml ```toml
[http.middlewares] [http.middlewares]
[http.middlewares.api-auth.basicauth] [http.middlewares.api-auth.basicAuth]
users = [ users = [
"test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/", "test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/",
"test2:$apr1$d9hr9HBB$4HxwgUir3HP4EsggP/QNo0", "test2:$apr1$d9hr9HBB$4HxwgUir3HP4EsggP/QNo0",

View file

@ -45,7 +45,7 @@ You can write these configuration elements:
# Add the middleware # Add the middleware
[http.middlewares] [http.middlewares]
[http.middlewares.my-basic-auth.BasicAuth] [http.middlewares.my-basic-auth.basicAuth]
users = ["test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/", users = ["test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/",
"test2:$apr1$d9hr9HBB$4HxwgUir3HP4EsggP/QNo0"] "test2:$apr1$d9hr9HBB$4HxwgUir3HP4EsggP/QNo0"]
usersFile = "etc/traefik/.htpasswd" usersFile = "etc/traefik/.htpasswd"
@ -53,37 +53,42 @@ You can write these configuration elements:
# Add the service # Add the service
[http.services] [http.services]
[http.services.service-foo] [http.services.service-foo]
[http.services.service-foo.LoadBalancer] [http.services.service-foo.loadBalancer]
[[http.services.service-foo.LoadBalancer.Servers]] [[http.services.service-foo.loadBalancer.servers]]
url = "http://foo/" url = "http://foo/"
[[http.services.service-foo.LoadBalancer.Servers]] [[http.services.service-foo.loadBalancer.servers]]
url = "http://bar/" url = "http://bar/"
``` ```
```yaml tab="YAML" ```yaml tab="YAML"
http: http:
# Add the router
routers: routers:
router0: router0:
entrypoints: entryPoints:
- web - web
middlewares: middlewares:
- my-basic-auth - my-basic-auth
service: service-foo service: service-foo
rule: Path(`foo`) rule: Path(`foo`)
# Add the middleware
middlewares: middlewares:
my-basic-auth: my-basic-auth:
basicAuth: basicAuth:
users: users:
- test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/ - test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/
- test2:$apr1$d9hr9HBB$4HxwgUir3HP4EsggP/QNo0 - test2:$apr1$d9hr9HBB$4HxwgUir3HP4EsggP/QNo0
usersfile: etc/traefik/.htpasswd usersFile: etc/traefik/.htpasswd
headerfield: ""
# Add the service
services: services:
service-foo: service-foo:
loadbalancer: loadBalancer:
servers: servers:
- url: http://foo/ - url: http://foo/
- url: http://bar/ - url: http://bar/
passHostHeader: false
``` ```
## Provider Configuration Options ## Provider Configuration Options
@ -170,7 +175,7 @@ Thus, it's possible to define easily lot of routers, services and TLS certificat
{{ end }} {{ end }}
[http.Services] [http.services]
{{ range $i, $e := until 100 }} {{ range $i, $e := until 100 }}
[http.services.service{{ $e }}] [http.services.service{{ $e }}]
# ... # ...
@ -185,7 +190,7 @@ Thus, it's possible to define easily lot of routers, services and TLS certificat
{{ end }} {{ end }}
[tcp.Services] [tcp.services]
{{ range $i, $e := until 100 }} {{ range $i, $e := until 100 }}
[http.services.service{{ $e }}] [http.services.service{{ $e }}]
# ... # ...
@ -193,9 +198,9 @@ Thus, it's possible to define easily lot of routers, services and TLS certificat
{{ range $i, $e := until 10 }} {{ range $i, $e := until 10 }}
[[tls.certificates]] [[tls.certificates]]
CertFile = "/etc/traefik/cert-{{ $e }}.pem" certFile = "/etc/traefik/cert-{{ $e }}.pem"
KeyFile = "/etc/traefik/cert-{{ $e }}.key" keyFile = "/etc/traefik/cert-{{ $e }}.key"
Store = ["my-store-foo-{{ $e }}", "my-store-bar-{{ $e }}"] store = ["my-store-foo-{{ $e }}", "my-store-bar-{{ $e }}"]
{{ end }} {{ end }}
[tls.config] [tls.config]
@ -237,8 +242,8 @@ Thus, it's possible to define easily lot of routers, services and TLS certificat
{{ range $i, $e := until 10 }} {{ range $i, $e := until 10 }}
tls: tls:
certificates: certificates:
- certfile: "/etc/traefik/cert-{{ $e }}.pem" - certFile: "/etc/traefik/cert-{{ $e }}.pem"
keyfile: "/etc/traefik/cert-{{ $e }}.key" keyFile: "/etc/traefik/cert-{{ $e }}.key"
store: store:
- "my-store-foo-{{ $e }}" - "my-store-foo-{{ $e }}"
- "my-store-bar-{{ $e }}" - "my-store-bar-{{ $e }}"

View file

@ -33,7 +33,7 @@ In this case, the endpoint is required.
Specifically, it may be set to the URL used by `kubectl proxy` to connect to a Kubernetes cluster using the granted authentication and authorization of the associated kubeconfig. Specifically, it may be set to the URL used by `kubectl proxy` to connect to a Kubernetes cluster using the granted authentication and authorization of the associated kubeconfig.
```toml tab="File" ```toml tab="File"
[Providers.KubernetesCRD] [providers.kubernetesCRD]
endpoint = "http://localhost:8080" endpoint = "http://localhost:8080"
# ... # ...
``` ```
@ -50,7 +50,7 @@ _Optional, Default=empty_
Bearer token used for the Kubernetes client configuration. Bearer token used for the Kubernetes client configuration.
```toml tab="File" ```toml tab="File"
[Providers.KubernetesCRD] [providers.kubernetesCRD]
token = "mytoken" token = "mytoken"
# ... # ...
``` ```
@ -68,7 +68,7 @@ Path to the certificate authority file.
Used for the Kubernetes client configuration. Used for the Kubernetes client configuration.
```toml tab="File" ```toml tab="File"
[Providers.KubernetesCRD] [providers.kubernetesCRD]
certAuthFilePath = "/my/ca.crt" certAuthFilePath = "/my/ca.crt"
# ... # ...
``` ```
@ -85,7 +85,7 @@ _Optional, Default: all namespaces (empty array)_
Array of namespaces to watch. Array of namespaces to watch.
```toml tab="File" ```toml tab="File"
[Providers.KubernetesCRD] [providers.kubernetesCRD]
namespaces = ["default", "production"] namespaces = ["default", "production"]
# ... # ...
``` ```
@ -105,7 +105,7 @@ A label selector can be defined to filter on specific Ingress objects only.
See [label-selectors](https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors) for details. See [label-selectors](https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors) for details.
```toml tab="File" ```toml tab="File"
[Providers.KubernetesCRD] [providers.kubernetesCRD]
labelselector = "A and not B" labelselector = "A and not B"
# ... # ...
``` ```
@ -125,7 +125,7 @@ If the parameter is non-empty, only Ingresses containing an annotation with the
Otherwise, Ingresses missing the annotation, having an empty value, or the value `traefik` are processed. Otherwise, Ingresses missing the annotation, having an empty value, or the value `traefik` are processed.
```toml tab="File" ```toml tab="File"
[Providers.KubernetesCRD] [providers.kubernetesCRD]
ingressClass = "traefik-internal" ingressClass = "traefik-internal"
# ... # ...
``` ```

View file

@ -58,7 +58,7 @@ _Optional_
Enables Marathon basic authentication. Enables Marathon basic authentication.
```toml tab="File" ```toml tab="File"
[marathon.basic] [providers.marathon.basic]
httpBasicAuthUser = "foo" httpBasicAuthUser = "foo"
httpBasicPassword = "bar" httpBasicPassword = "bar"
``` ```
@ -247,10 +247,10 @@ _Optional_
TLS client configuration. [tls/#Config](https://golang.org/pkg/crypto/tls/#Config). TLS client configuration. [tls/#Config](https://golang.org/pkg/crypto/tls/#Config).
```toml tab="File" ```toml tab="File"
[marathon.TLS] [providers.marathon.tls]
CA = "/etc/ssl/ca.crt" ca = "/etc/ssl/ca.crt"
Cert = "/etc/ssl/marathon.cert" cert = "/etc/ssl/marathon.cert"
Key = "/etc/ssl/marathon.key" key = "/etc/ssl/marathon.key"
insecureSkipVerify = true insecureSkipVerify = true
``` ```
@ -296,23 +296,23 @@ and the router automatically gets a rule defined by defaultRule (if no rule for
### Routers ### Routers
To update the configuration of the Router automatically attached to the application, To update the configuration of the Router automatically attached to the application,
add labels starting with `traefik.HTTP.Routers.{router-name-of-your-choice}.` and followed by the option you want to change. add labels starting with `traefik.http.routers.{router-name-of-your-choice}.` and followed by the option you want to change.
For example, to change the routing rule, you could add the label ```traefik.HTTP.Routers.Routername.Rule=Host(`my-domain`)```. For example, to change the routing rule, you could add the label ```traefik.http.routers.routername.rule=Host(`my-domain`)```.
Every [Router](../routing/routers/index.md) parameter can be updated this way. Every [Router](../routing/routers/index.md) parameter can be updated this way.
### Services ### Services
To update the configuration of the Service automatically attached to the container, To update the configuration of the Service automatically attached to the container,
add labels starting with `traefik.HTTP.Services.{service-name-of-your-choice}.`, followed by the option you want to change. add labels starting with `traefik.http.services.{service-name-of-your-choice}.`, followed by the option you want to change.
For example, to change the passhostheader behavior, you'd add the label `traefik.HTTP.Services.Servicename.LoadBalancer.PassHostHeader=false`. For example, to change the passHostHeader behavior, you'd add the label `traefik.http.services.servicename.loadbalancer.passhostheader=false`.
Every [Service](../routing/services/index.md) parameter can be updated this way. Every [Service](../routing/services/index.md) parameter can be updated this way.
### Middleware ### Middleware
You can declare pieces of middleware using labels starting with `traefik.HTTP.Middlewares.{middleware-name-of-your-choice}.`, followed by the middleware type/options. You can declare pieces of middleware using labels starting with `traefik.http.middlewares.{middleware-name-of-your-choice}.`, followed by the middleware type/options.
For example, to declare a middleware [`redirectscheme`](../middlewares/redirectscheme.md) named `my-redirect`, you'd write `traefik.HTTP.Middlewares.my-redirect.RedirectScheme.Scheme: https`. For example, to declare a middleware [`redirectscheme`](../middlewares/redirectscheme.md) named `my-redirect`, you'd write `traefik.http.middlewares.my-redirect.redirectscheme.scheme: https`.
??? example "Declaring and Referencing a Middleware" ??? example "Declaring and Referencing a Middleware"

View file

@ -19,7 +19,7 @@ Attach labels to your services and let Traefik do the rest!
Enabling the rancher provider Enabling the rancher provider
```toml ```toml
[Providers.Rancher] [providers.rancher]
``` ```
Attaching labels to services Attaching labels to services
@ -58,7 +58,7 @@ The service name can be accessed as the `Name` identifier,
and the template has access to all the labels defined on this container. and the template has access to all the labels defined on this container.
```toml tab="File" ```toml tab="File"
[Providers.Rancher] [providers.rancher]
defaultRule = "Host(`{{ .Name }}.{{ index .Labels \"customLabel\"}}`)" defaultRule = "Host(`{{ .Name }}.{{ index .Labels \"customLabel\"}}`)"
# ... # ...
``` ```

View file

@ -1,20 +1,20 @@
# Enable Rancher Provider. # Enable Rancher Provider.
[Providers.Rancher] [providers.rancher]
# Expose Rancher services by default in Traefik. # Expose Rancher services by default in Traefik.
ExposedByDefault = true exposedByDefault = true
# Enable watch Rancher changes. # Enable watch Rancher changes.
Watch = true watch = true
# Filter services with unhealthy states and inactive states. # Filter services with unhealthy states and inactive states.
EnableServiceHealthFilter = true enableServiceHealthFilter = true
# Defines the polling interval (in seconds). # Defines the polling interval (in seconds).
RefreshSeconds = true refreshSeconds = true
# Poll the Rancher metadata service for changes every `rancher.refreshSeconds`, which is less accurate # Poll the Rancher metadata service for changes every `rancher.refreshSeconds`, which is less accurate
IntervalPoll = false intervalPoll = false
# Prefix used for accessing the Rancher metadata service # Prefix used for accessing the Rancher metadata service
Prefix = "/latest" prefix = "/latest"

View file

@ -3,6 +3,8 @@
Dynamic configuration with Docker Labels Dynamic configuration with Docker Labels
{: .subtitle } {: .subtitle }
The labels are case insensitive.
```yaml ```yaml
--8<-- "content/reference/dynamic-configuration/labels.yml" --8<-- "content/reference/dynamic-configuration/labels.yml"
``` ```

View file

@ -1,259 +1,248 @@
[HTTP] [http]
[http.routers]
[HTTP.Routers] [http.routers.Router0]
entryPoints = ["foobar", "foobar"]
[HTTP.Routers.Router0] middlewares = ["foobar", "foobar"]
EntryPoints = ["foobar", "foobar"] service = "foobar"
Middlewares = ["foobar", "foobar"] rule = "foobar"
Service = "foobar"
Rule = "foobar"
priority = 42 priority = 42
[HTTP.Routers.Router0.tls] [http.routers.Router0.tls]
options = "TLS0" options = "TLS0"
[http.middlewares]
[HTTP.Middlewares] [http.middlewares.Middleware0]
[http.middlewares.Middleware0.addPrefix]
[HTTP.Middlewares.Middleware0.AddPrefix] prefix = "foobar"
Prefix = "foobar" [http.middlewares.Middleware1]
[http.middlewares.Middleware1.stripPrefix]
[HTTP.Middlewares.Middleware1.StripPrefix] prefixes = ["foobar", "foobar"]
Prefixes = ["foobar", "foobar"] [http.middlewares.Middleware10]
[http.middlewares.Middleware10.rateLimit]
[HTTP.Middlewares.Middleware2.StripPrefixRegex] extractorFunc = "foobar"
Regex = ["foobar", "foobar"] [http.middlewares.Middleware10.rateLimit.rateSet]
[http.middlewares.Middleware10.rateLimit.rateSet.Rate0]
[HTTP.Middlewares.Middleware3.ReplacePath] period = 42
Path = "foobar" average = 42
burst = 42
[HTTP.Middlewares.Middleware4.ReplacePathRegex] [http.middlewares.Middleware10.rateLimit.rateSet.Rate1]
Regex = "foobar" period = 42
Replacement = "foobar" average = 42
burst = 42
[HTTP.Middlewares.Middleware5.Chain] [http.middlewares.Middleware11]
Middlewares = ["foobar", "foobar"] [http.middlewares.Middleware11.redirectRegex]
regex = "foobar"
[HTTP.Middlewares.Middleware6.IPWhiteList] replacement = "foobar"
SourceRange = ["foobar", "foobar"] permanent = true
[http.middlewares.Middleware12]
[HTTP.Middlewares.Middleware7.IPWhiteList.IPStrategy] [http.middlewares.Middleware12.redirectScheme]
Depth = 42 scheme = "foobar"
ExcludedIPs = ["foobar", "foobar"] port = "foobar"
permanent = true
[HTTP.Middlewares.Middleware8.Headers] [http.middlewares.Middleware13]
AccessControlAllowCredentials = true [http.middlewares.Middleware13.basicAuth]
AccessControlAllowHeaders = ["foobar", "foobar"] users = ["foobar", "foobar"]
AccessControlAllowMethods = ["foobar", "foobar"] usersFile = "foobar"
AccessControlAllowOrigin = "foobar" realm = "foobar"
AccessControlExposeHeaders = ["foobar", "foobar"] removeHeader = true
AccessControlMaxAge = 42 headerField = "foobar"
AddVaryHeader = true [http.middlewares.Middleware14]
AllowedHosts = ["foobar", "foobar"] [http.middlewares.Middleware14.digestAuth]
HostsProxyHeaders = ["foobar", "foobar"] users = ["foobar", "foobar"]
SSLRedirect = true usersFile = "foobar"
SSLTemporaryRedirect = true removeHeader = true
SSLHost = "foobar" realm = "foobar"
SSLForceHost = true headerField = "foobar"
STSSeconds = 42 [http.middlewares.Middleware15]
STSIncludeSubdomains = true [http.middlewares.Middleware15.forwardAuth]
STSPreload = true address = "foobar"
ForceSTSHeader = true trustForwardHeader = true
FrameDeny = true authResponseHeaders = ["foobar", "foobar"]
CustomFrameOptionsValue = "foobar" [http.middlewares.Middleware15.forwardAuth.tls]
ContentTypeNosniff = true ca = "foobar"
BrowserXSSFilter = true caOptional = true
CustomBrowserXSSValue = "foobar" cert = "foobar"
ContentSecurityPolicy = "foobar" key = "foobar"
PublicKey = "foobar" insecureSkipVerify = true
ReferrerPolicy = "foobar" [http.middlewares.Middleware16]
IsDevelopment = true [http.middlewares.Middleware16.maxConn]
[HTTP.Middlewares.Middleware8.Headers.CustomRequestHeaders] amount = 42
extractorFunc = "foobar"
[http.middlewares.Middleware17]
[http.middlewares.Middleware17.buffering]
maxRequestBodyBytes = 42
memRequestBodyBytes = 42
maxResponseBodyBytes = 42
memResponseBodyBytes = 42
retryExpression = "foobar"
[http.middlewares.Middleware18]
[http.middlewares.Middleware18.circuitBreaker]
expression = "foobar"
[http.middlewares.Middleware19]
[http.middlewares.Middleware19.compress]
[http.middlewares.Middleware2]
[http.middlewares.Middleware2.stripPrefixRegex]
regex = ["foobar", "foobar"]
[http.middlewares.Middleware20]
[http.middlewares.Middleware20.passTLSClientCert]
pem = true
[http.middlewares.Middleware20.passTLSClientCert.info]
notAfter = true
notBefore = true
sans = true
[http.middlewares.Middleware20.passTLSClientCert.info.subject]
country = true
province = true
locality = true
organization = true
commonName = true
serialNumber = true
domainComponent = true
[http.middlewares.Middleware20.passTLSClientCert.info.issuer]
country = true
province = true
locality = true
organization = true
commonName = true
serialNumber = true
domainComponent = true
[http.middlewares.Middleware21]
[http.middlewares.Middleware21.retry]
attemps = 42
[http.middlewares.Middleware3]
[http.middlewares.Middleware3.replacePath]
path = "foobar"
[http.middlewares.Middleware4]
[http.middlewares.Middleware4.replacePathRegex]
regex = "foobar"
replacement = "foobar"
[http.middlewares.Middleware5]
[http.middlewares.Middleware5.chain]
middlewares = ["foobar", "foobar"]
[http.middlewares.Middleware6]
[http.middlewares.Middleware6.ipWhiteList]
sourceRange = ["foobar", "foobar"]
[http.middlewares.Middleware7]
[http.middlewares.Middleware7.ipWhiteList]
[http.middlewares.Middleware7.ipWhiteList.ipStrategy]
depth = 42
excludedIPs = ["foobar", "foobar"]
[http.middlewares.Middleware8]
[http.middlewares.Middleware8.headers]
accessControlAllowCredentials = true
accessControlAllowHeaders = ["foobar", "foobar"]
accessControlAllowMethods = ["foobar", "foobar"]
accessControlAllowOrigin = "foobar"
accessControlExposeHeaders = ["foobar", "foobar"]
accessControlMaxAge = 42
addVaryHeader = true
allowedHosts = ["foobar", "foobar"]
hostsProxyHeaders = ["foobar", "foobar"]
sslRedirect = true
sslTemporaryRedirect = true
sslHost = "foobar"
sslForceHost = true
stsSeconds = 42
stsIncludeSubdomains = true
stsPreload = true
forceSTSHeader = true
frameDeny = true
customFrameOptionsValue = "foobar"
contentTypeNosniff = true
browserXssFilter = true
customBrowserXSSValue = "foobar"
contentSecurityPolicy = "foobar"
publicKey = "foobar"
referrerPolicy = "foobar"
isDevelopment = true
[http.middlewares.Middleware8.headers.customRequestHeaders]
name0 = "foobar" name0 = "foobar"
name1 = "foobar" name1 = "foobar"
[HTTP.Middlewares.Middleware8.Headers.CustomResponseHeaders] [http.middlewares.Middleware8.headers.customResponseHeaders]
name0 = "foobar" name0 = "foobar"
name1 = "foobar" name1 = "foobar"
[HTTP.Middlewares.Middleware8.Headers.SSLProxyHeaders] [http.middlewares.Middleware8.headers.sslProxyHeaders]
name0 = "foobar" name0 = "foobar"
name1 = "foobar" name1 = "foobar"
[http.middlewares.Middleware9]
[http.middlewares.Middleware9.errors]
status = ["foobar", "foobar"]
service = "foobar"
query = "foobar"
[http.services]
[http.services.Service0]
[http.services.Service0.loadBalancer]
passHostHeader = true
[http.services.Service0.loadBalancer.stickiness]
cookieName = "foobar"
[HTTP.Middlewares.Middleware9.Errors] [[http.services.Service0.loadBalancer.servers]]
Status = ["foobar", "foobar"] url = "foobar"
Service = "foobar"
Query = "foobar"
[HTTP.Middlewares.Middleware10.RateLimit] [[http.services.Service0.loadBalancer.servers]]
ExtractorFunc = "foobar" url = "foobar"
[HTTP.Middlewares.Middleware10.RateLimit.RateSet] [http.services.Service0.loadBalancer.healthCheck]
[HTTP.Middlewares.Middleware10.RateLimit.RateSet.Rate0] scheme = "foobar"
Period = 42 path = "foobar"
Average = 42 port = 42
Burst = 42 interval = "foobar"
[HTTP.Middlewares.Middleware10.RateLimit.RateSet.Rate1] timeout = "foobar"
Period = 42 hostname = "foobar"
Average = 42 [http.services.Service0.loadBalancer.healthCheck.headers]
Burst = 42
[HTTP.Middlewares.Middleware11.RedirectRegex]
Regex = "foobar"
Replacement = "foobar"
Permanent = true
[HTTP.Middlewares.Middleware12.RedirectScheme]
Scheme = "foobar"
Port = "foobar"
Permanent = true
[HTTP.Middlewares.Middleware13.BasicAuth]
Users = ["foobar", "foobar"]
UsersFile = "foobar"
Realm = "foobar"
RemoveHeader = true
HeaderField = "foobar"
[HTTP.Middlewares.Middleware14.DigestAuth]
Users = ["foobar", "foobar"]
UsersFile = "foobar"
RemoveHeader = true
Realm = "foobar"
HeaderField = "foobar"
[HTTP.Middlewares.Middleware15.ForwardAuth]
Address = "foobar"
TrustForwardHeader = true
AuthResponseHeaders = ["foobar", "foobar"]
[HTTP.Middlewares.Middleware15.ForwardAuth.TLS]
CA = "foobar"
CAOptional = true
Cert = "foobar"
Key = "foobar"
InsecureSkipVerify = true
[HTTP.Middlewares.Middleware16.MaxConn]
Amount = 42
ExtractorFunc = "foobar"
[HTTP.Middlewares.Middleware17.Buffering]
MaxRequestBodyBytes = 42
MemRequestBodyBytes = 42
MaxResponseBodyBytes = 42
MemResponseBodyBytes = 42
RetryExpression = "foobar"
[HTTP.Middlewares.Middleware18.CircuitBreaker]
Expression = "foobar"
[HTTP.Middlewares.Middleware19.Compress]
[HTTP.Middlewares.Middleware20.PassTLSClientCert]
PEM = true
[HTTP.Middlewares.Middleware20.PassTLSClientCert.Info]
NotAfter = true
NotBefore = true
Sans = true
[HTTP.Middlewares.Middleware20.PassTLSClientCert.Info.Subject]
Country = true
Province = true
Locality = true
Organization = true
CommonName = true
SerialNumber = true
DomainComponent = true
[HTTP.Middlewares.Middleware20.PassTLSClientCert.Info.Issuer]
Country = true
Province = true
Locality = true
Organization = true
CommonName = true
SerialNumber = true
DomainComponent = true
[HTTP.Middlewares.Middleware21.Retry]
Attempts = 42
[HTTP.Services]
[HTTP.Services.Service0]
[HTTP.Services.Service0.LoadBalancer]
PassHostHeader = true
[[HTTP.Services.Service0.LoadBalancer.Servers]]
URL = "foobar"
[HTTP.Services.Service0.LoadBalancer.Stickiness]
CookieName = "foobar"
[[HTTP.Services.Service0.LoadBalancer.Servers]]
URL = "foobar"
[HTTP.Services.Service0.LoadBalancer.HealthCheck]
Scheme = "foobar"
Path = "foobar"
Port = 42
Interval = "foobar"
Timeout = "foobar"
Hostname = "foobar"
[HTTP.Services.Service0.LoadBalancer.HealthCheck.Headers]
name0 = "foobar" name0 = "foobar"
name1 = "foobar" name1 = "foobar"
[HTTP.Services.Service0.LoadBalancer.ResponseForwarding] [http.services.Service0.loadBalancer.responseForwarding]
FlushInterval = "foobar" flushInterval = "foobar"
[TCP] [tcp]
[tcp.routers]
[TCP.Routers] [tcp.routers.TCPRouter0]
entryPoints = ["foobar", "foobar"]
[TCP.Routers.TCPRouter0] service = "foobar"
EntryPoints = ["foobar", "foobar"] rule = "foobar"
Service = "foobar" [tcp.routers.TCPRouter0.tls]
Rule = "foobar"
[TCP.Routers.TCPRouter0.tls]
passthrough = true passthrough = true
options = "TLS1" options = "TLS1"
[tcp.services]
[tcp.services.TCPService0]
[tcp.services.TCPService0.loadBalancer]
[TCP.Services] [[tcp.services.TCPService0.loadBalancer.servers]]
address = "foobar"
[TCP.Services.TCPService0] [[tcp.services.TCPService0.loadBalancer.servers]]
[TCP.Services.TCPService0.LoadBalancer] address = "foobar"
[[TCP.Services.TCPService0.LoadBalancer.Servers]] [tls]
Address = "foobar"
[[TCP.Services.TCPService0.LoadBalancer.Servers]] [[tls.certificates]]
Address = "foobar" certFile = "foobar"
keyFile = "foobar"
stores = ["foobar", "foobar"]
[TLS] [[tls.certificates]]
certFile = "foobar"
[[TLS.Certificates]] keyFile = "foobar"
Stores = ["foobar", "foobar"] stores = ["foobar", "foobar"]
CertFile = "foobar" [tls.options]
KeyFile = "foobar" [tls.options.TLS0]
minVersion = "foobar"
[[TLS.Certificates]] cipherSuites = ["foobar", "foobar"]
Stores = ["foobar", "foobar"] sniStrict = true
CertFile = "foobar" [tls.options.TLS0.clientCA]
KeyFile = "foobar" files = ["foobar", "foobar"]
optional = true
[TLS.Options] [tls.options.TLS1]
[TLS.Options.TLS0] minVersion = "foobar"
MinVersion = "foobar" cipherSuites = ["foobar", "foobar"]
CipherSuites = ["foobar", "foobar"] sniStrict = true
SniStrict = true [tls.options.TLS1.clientCA]
[TLS.Options.TLS0.ClientCA] files = ["foobar", "foobar"]
Files = ["foobar", "foobar"] optional = true
Optional = true [tls.stores]
[TLS.Options.TLS1] [tls.stores.Store0]
MinVersion = "foobar" [tls.stores.Store0.defaultCertificate]
CipherSuites = ["foobar", "foobar"] certFile = "foobar"
SniStrict = true keyFile = "foobar"
[TLS.Options.TLS1.ClientCA] [tls.stores.Store1]
Files = ["foobar", "foobar"] [tls.stores.Store1.defaultCertificate]
Optional = true certFile = "foobar"
keyFile = "foobar"
[TLS.Stores]
[TLS.Stores.Store0]
[TLS.Stores.Store0.DefaultCertificate]
CertFile = "foobar"
KeyFile = "foobar"
[TLS.Stores.Store1]
[TLS.Stores.Store1.DefaultCertificate]
CertFile = "foobar"
KeyFile = "foobar"

View file

@ -1,7 +1,7 @@
http: http:
routers: routers:
Router0: Router0:
entrypoints: entryPoints:
- foobar - foobar
- foobar - foobar
middlewares: middlewares:
@ -10,8 +10,7 @@ http:
service: foobar service: foobar
rule: foobar rule: foobar
priority: 42 priority: 42
tls: tls: {}
options: TLS0
middlewares: middlewares:
Middleware0: Middleware0:
addPrefix: addPrefix:
@ -40,65 +39,63 @@ http:
- foobar - foobar
Middleware6: Middleware6:
ipWhiteList: ipWhiteList:
sourcerange: sourceRange:
- foobar - foobar
- foobar - foobar
ipstrategy: null
Middleware7: Middleware7:
ipWhiteList: ipWhiteList:
sourcerange: [] ipStrategy:
ipstrategy:
depth: 42 depth: 42
excludedips: excludedIPs:
- foobar - foobar
- foobar - foobar
Middleware8: Middleware8:
headers: headers:
customrequestheaders: customRequestHeaders:
name0: foobar name0: foobar
name1: foobar name1: foobar
customresponseheaders: customResponseHeaders:
name0: foobar name0: foobar
name1: foobar name1: foobar
accesscontrolallowcredentials: true accessControlAllowCredentials: true
accesscontrolallowheaders: accessControlAllowHeaders:
- foobar - foobar
- foobar - foobar
accesscontrolallowmethods: accessControlAllowMethods:
- foobar - foobar
- foobar - foobar
accesscontrolalloworigin: foobar accessControlAllowOrigin: foobar
accesscontrolexposeheaders: accessControlExposeHeaders:
- foobar - foobar
- foobar - foobar
accesscontrolmaxage: 42 accessControlMaxAge: 42
addvaryheader: true addVaryHeader: true
allowedhosts: allowedHosts:
- foobar - foobar
- foobar - foobar
hostsproxyheaders: hostsProxyHeaders:
- foobar - foobar
- foobar - foobar
sslredirect: true sslRedirect: true
ssltemporaryredirect: true sslTemporaryRedirect: true
sslhost: foobar sslHost: foobar
sslproxyheaders: sslProxyHeaders:
name0: foobar name0: foobar
name1: foobar name1: foobar
sslforcehost: true sslForceHost: true
stsseconds: 42 stsSeconds: 42
stsincludesubdomains: true stsIncludeSubdomains: true
stspreload: true stsPreload: true
forcestsheader: true forceSTSHeader: true
framedeny: true frameDeny: true
customframeoptionsvalue: foobar customFrameOptionsValue: foobar
contenttypenosniff: true contentTypeNosniff: true
browserxssfilter: true browserXssFilter: true
custombrowserxssvalue: foobar customBrowserXSSValue: foobar
contentsecuritypolicy: foobar contentSecurityPolicy: foobar
publickey: foobar publicKey: foobar
referrerpolicy: foobar referrerPolicy: foobar
isdevelopment: true isDevelopment: true
Middleware9: Middleware9:
errors: errors:
status: status:
@ -108,7 +105,7 @@ http:
query: foobar query: foobar
Middleware10: Middleware10:
rateLimit: rateLimit:
rateset: rateSet:
Rate0: Rate0:
period: 42000000000 period: 42000000000
average: 42 average: 42
@ -117,7 +114,7 @@ http:
period: 42000000000 period: 42000000000
average: 42 average: 42
burst: 42 burst: 42
extractorfunc: foobar extractorFunc: foobar
Middleware11: Middleware11:
redirectRegex: redirectRegex:
regex: foobar regex: foobar
@ -133,43 +130,43 @@ http:
users: users:
- foobar - foobar
- foobar - foobar
usersfile: foobar usersFile: foobar
realm: foobar realm: foobar
removeheader: true removeHeader: true
headerfield: foobar headerField: foobar
Middleware14: Middleware14:
digestAuth: digestAuth:
users: users:
- foobar - foobar
- foobar - foobar
usersfile: foobar usersFile: foobar
removeheader: true removeHeader: true
realm: foobar realm: foobar
headerfield: foobar headerField: foobar
Middleware15: Middleware15:
forwardAuth: forwardAuth:
address: foobar address: foobar
tls: tls:
ca: foobar ca: foobar
caoptional: true caOptional: true
cert: foobar cert: foobar
key: foobar key: foobar
insecureskipverify: true insecureSkipVerify: true
trustforwardheader: true trustForwardHeader: true
authresponseheaders: authResponseHeaders:
- foobar - foobar
- foobar - foobar
Middleware16: Middleware16:
maxConn: maxConn:
amount: 42 amount: 42
extractorfunc: foobar extractorFunc: foobar
Middleware17: Middleware17:
buffering: buffering:
maxrequestbodybytes: 42 maxRequestBodyBytes: 42
memrequestbodybytes: 42 memRequestBodyBytes: 42
maxresponsebodybytes: 42 maxResponseBodyBytes: 42
memresponsebodybytes: 42 memResponseBodyBytes: 42
retryexpression: foobar retryExpression: foobar
Middleware18: Middleware18:
circuitBreaker: circuitBreaker:
expression: foobar expression: foobar
@ -179,43 +176,37 @@ http:
passTLSClientCert: passTLSClientCert:
pem: true pem: true
info: info:
notafter: true notAfter: true
notbefore: true notBefore: true
sans: true sans: true
subject: subject:
country: true country: true
province: true province: true
locality: true locality: true
organization: true organization: true
commonname: true commonName: true
serialnumber: true serialNumber: true
domaincomponent: true domainComponent: true
issuer: issuer:
country: true country: true
province: true province: true
locality: true locality: true
organization: true organization: true
commonname: true commonName: true
serialnumber: true serialNumber: true
domaincomponent: true domainComponent: true
Middleware21: Middleware21:
retry: retry:
attempts: 42 attemps: 42
services: services:
Service0: Service0:
loadbalancer: loadBalancer:
stickiness: stickiness:
cookiename: foobar cookieName: foobar
securecookie: false
httponlycookie: false
servers: servers:
- url: foobar - url: foobar
scheme: ""
port: ""
- url: foobar - url: foobar
scheme: "" healthCheck:
port: ""
healthcheck:
scheme: foobar scheme: foobar
path: foobar path: foobar
port: 42 port: 42
@ -225,70 +216,66 @@ http:
headers: headers:
name0: foobar name0: foobar
name1: foobar name1: foobar
passhostheader: true passHostHeader: true
responseforwarding: responseForwarding:
flushinterval: foobar flushInterval: foobar
tcp: tcp:
routers: routers:
TCPRouter0: TCPRouter0:
entrypoints: entryPoints:
- foobar - foobar
- foobar - foobar
service: foobar service: foobar
rule: foobar rule: foobar
tls: tls:
passthrough: true passthrough: true
options: TLS1
services: services:
TCPService0: TCPService0:
loadbalancer: loadBalancer:
servers: servers:
- address: foobar - address: foobar
port: ""
- address: foobar - address: foobar
port: ""
tls: tls:
- stores: certificates:
- certFile: foobar
keyFile: foobar
stores:
- foobar - foobar
- foobar - foobar
certificate: - certFile: foobar
certfile: foobar keyFile: foobar
keyfile: foobar stores:
- stores:
- foobar - foobar
- foobar - foobar
certificate: options:
certfile: foobar
keyfile: foobar
tlsoptions:
TLS0: TLS0:
minversion: foobar minVersion: foobar
ciphersuites: cipherSuites:
- foobar - foobar
- foobar - foobar
clientca: clientCA:
files: files:
- foobar - foobar
- foobar - foobar
optional: true optional: true
snistrict: true sniStrict: true
TLS1: TLS1:
minversion: foobar minVersion: foobar
ciphersuites: cipherSuites:
- foobar - foobar
- foobar - foobar
clientca: clientCA:
files: files:
- foobar - foobar
- foobar - foobar
optional: true optional: true
snistrict: true sniStrict: true
tlsstores: stores:
Store0: Store0:
defaultcertificate: defaultCertificate:
certfile: foobar certFile: foobar
keyfile: foobar keyFile: foobar
Store1: Store1:
defaultcertificate: defaultCertificate:
certfile: foobar certFile: foobar
keyfile: foobar keyFile: foobar

View file

@ -1,154 +1,154 @@
labels: labels:
- "traefik.HTTP.Middlewares.Middleware0.AddPrefix.Prefix=foobar" - "traefik.http.middlewares.Middleware0.addprefix.prefix=foobar"
- "traefik.HTTP.Middlewares.Middleware1.BasicAuth.HeaderField=foobar" - "traefik.http.middlewares.Middleware1.basicauth.headerfield=foobar"
- "traefik.HTTP.Middlewares.Middleware1.BasicAuth.Realm=foobar" - "traefik.http.middlewares.Middleware1.basicauth.realm=foobar"
- "traefik.HTTP.Middlewares.Middleware1.BasicAuth.RemoveHeader=true" - "traefik.http.middlewares.Middleware1.basicauth.removeheader=true"
- "traefik.HTTP.Middlewares.Middleware1.BasicAuth.Users=foobar, fiibar" - "traefik.http.middlewares.Middleware1.basicauth.users=foobar, fiibar"
- "traefik.HTTP.Middlewares.Middleware1.BasicAuth.UsersFile=foobar" - "traefik.http.middlewares.Middleware1.basicauth.usersfile=foobar"
- "traefik.HTTP.Middlewares.Middleware2.Buffering.MaxRequestBodyBytes=42" - "traefik.http.middlewares.Middleware2.buffering.maxrequestbodybytes=42"
- "traefik.HTTP.Middlewares.Middleware2.Buffering.MaxResponseBodyBytes=42" - "traefik.http.middlewares.Middleware2.buffering.maxresponsebodybytes=42"
- "traefik.HTTP.Middlewares.Middleware2.Buffering.MemRequestBodyBytes=42" - "traefik.http.middlewares.Middleware2.buffering.memrequestbodybytes=42"
- "traefik.HTTP.Middlewares.Middleware2.Buffering.MemResponseBodyBytes=42" - "traefik.http.middlewares.Middleware2.buffering.memresponsebodybytes=42"
- "traefik.HTTP.Middlewares.Middleware2.Buffering.RetryExpression=foobar" - "traefik.http.middlewares.Middleware2.buffering.retryexpression=foobar"
- "traefik.HTTP.Middlewares.Middleware3.Chain.Middlewares=foobar, fiibar" - "traefik.http.middlewares.Middleware3.chain.middlewares=foobar, fiibar"
- "traefik.HTTP.Middlewares.Middleware4.CircuitBreaker.Expression=foobar" - "traefik.http.middlewares.Middleware4.circuitbreaker.expression=foobar"
- "traefik.HTTP.Middlewares.Middleware5.DigestAuth.HeaderField=foobar" - "traefik.http.middlewares.Middleware5.digestauth.headerfield=foobar"
- "traefik.HTTP.Middlewares.Middleware5.DigestAuth.Realm=foobar" - "traefik.http.middlewares.Middleware5.digestauth.realm=foobar"
- "traefik.HTTP.Middlewares.Middleware5.DigestAuth.RemoveHeader=true" - "traefik.http.middlewares.Middleware5.digestauth.removeheader=true"
- "traefik.HTTP.Middlewares.Middleware5.DigestAuth.Users=foobar, fiibar" - "traefik.http.middlewares.Middleware5.digestauth.users=foobar, fiibar"
- "traefik.HTTP.Middlewares.Middleware5.DigestAuth.UsersFile=foobar" - "traefik.http.middlewares.Middleware5.digestauth.usersfile=foobar"
- "traefik.HTTP.Middlewares.Middleware6.Errors.Query=foobar" - "traefik.http.middlewares.Middleware6.errors.query=foobar"
- "traefik.HTTP.Middlewares.Middleware6.Errors.Service=foobar" - "traefik.http.middlewares.Middleware6.errors.service=foobar"
- "traefik.HTTP.Middlewares.Middleware6.Errors.Status=foobar, fiibar" - "traefik.http.middlewares.Middleware6.errors.status=foobar, fiibar"
- "traefik.HTTP.Middlewares.Middleware7.ForwardAuth.Address=foobar" - "traefik.http.middlewares.Middleware7.forwardauth.address=foobar"
- "traefik.HTTP.Middlewares.Middleware7.ForwardAuth.AuthResponseHeaders=foobar, fiibar" - "traefik.http.middlewares.Middleware7.forwardauth.authresponseheaders=foobar, fiibar"
- "traefik.HTTP.Middlewares.Middleware7.ForwardAuth.TLS.CA=foobar" - "traefik.http.middlewares.Middleware7.forwardauth.tls.ca=foobar"
- "traefik.HTTP.Middlewares.Middleware7.ForwardAuth.TLS.CAOptional=true" - "traefik.http.middlewares.Middleware7.forwardauth.tls.caoptional=true"
- "traefik.HTTP.Middlewares.Middleware7.ForwardAuth.TLS.Cert=foobar" - "traefik.http.middlewares.Middleware7.forwardauth.tls.cert=foobar"
- "traefik.HTTP.Middlewares.Middleware7.ForwardAuth.TLS.InsecureSkipVerify=true" - "traefik.http.middlewares.Middleware7.forwardauth.tls.insecureskipverify=true"
- "traefik.HTTP.Middlewares.Middleware7.ForwardAuth.TLS.Key=foobar" - "traefik.http.middlewares.Middleware7.forwardauth.tls.key=foobar"
- "traefik.HTTP.Middlewares.Middleware7.ForwardAuth.TrustForwardHeader=true" - "traefik.http.middlewares.Middleware7.forwardauth.trustforwardheader=true"
- "traefik.HTTP.Middlewares.Middleware8.Headers.AccessControlAllowCredentials=true" - "traefik.http.middlewares.Middleware8.headers.accesscontrolallowcredentials=true"
- "traefik.HTTP.Middlewares.Middleware8.Headers.AccessControlAllowHeaders=X-foobar, X-fiibar" - "traefik.http.middlewares.Middleware8.headers.accesscontrolallowheaders=x-foobar, x-fiibar"
- "traefik.HTTP.Middlewares.Middleware8.Headers.AccessControlAllowMethods=GET, PUT" - "traefik.http.middlewares.Middleware8.headers.accesscontrolallowmethods=get, put"
- "traefik.HTTP.Middlewares.Middleware8.Headers.AccessControlAllowOrigin=foobar" - "traefik.http.middlewares.Middleware8.headers.accesscontrolalloworigin=foobar"
- "traefik.HTTP.Middlewares.Middleware8.Headers.AccessControlExposeHeaders=X-foobar, X-fiibar" - "traefik.http.middlewares.Middleware8.headers.accesscontrolexposeheaders=x-foobar, x-fiibar"
- "traefik.HTTP.Middlewares.Middleware8.Headers.AccessControlMaxAge=200" - "traefik.http.middlewares.Middleware8.headers.accesscontrolmaxage=200"
- "traefik.HTTP.Middlewares.Middleware8.Headers.AddVaryHeader=true" - "traefik.http.middlewares.Middleware8.headers.addvaryheader=true"
- "traefik.HTTP.Middlewares.Middleware8.Headers.AllowedHosts=foobar, fiibar" - "traefik.http.middlewares.Middleware8.headers.allowedhosts=foobar, fiibar"
- "traefik.HTTP.Middlewares.Middleware8.Headers.BrowserXSSFilter=true" - "traefik.http.middlewares.Middleware8.headers.browserxssfilter=true"
- "traefik.HTTP.Middlewares.Middleware8.Headers.ContentSecurityPolicy=foobar" - "traefik.http.middlewares.Middleware8.headers.contentsecuritypolicy=foobar"
- "traefik.HTTP.Middlewares.Middleware8.Headers.ContentTypeNosniff=true" - "traefik.http.middlewares.Middleware8.headers.contenttypenosniff=true"
- "traefik.HTTP.Middlewares.Middleware8.Headers.CustomBrowserXSSValue=foobar" - "traefik.http.middlewares.Middleware8.headers.custombrowserxssvalue=foobar"
- "traefik.HTTP.Middlewares.Middleware8.Headers.CustomFrameOptionsValue=foobar" - "traefik.http.middlewares.Middleware8.headers.customframeoptionsvalue=foobar"
- "traefik.HTTP.Middlewares.Middleware8.Headers.CustomRequestHeaders.name0=foobar" - "traefik.http.middlewares.Middleware8.headers.customrequestheaders.name0=foobar"
- "traefik.HTTP.Middlewares.Middleware8.Headers.CustomRequestHeaders.name1=foobar" - "traefik.http.middlewares.Middleware8.headers.customrequestheaders.name1=foobar"
- "traefik.HTTP.Middlewares.Middleware8.Headers.CustomResponseHeaders.name0=foobar" - "traefik.http.middlewares.Middleware8.headers.customresponseheaders.name0=foobar"
- "traefik.HTTP.Middlewares.Middleware8.Headers.CustomResponseHeaders.name1=foobar" - "traefik.http.middlewares.Middleware8.headers.customresponseheaders.name1=foobar"
- "traefik.HTTP.Middlewares.Middleware8.Headers.ForceSTSHeader=true" - "traefik.http.middlewares.Middleware8.headers.forcestsheader=true"
- "traefik.HTTP.Middlewares.Middleware8.Headers.FrameDeny=true" - "traefik.http.middlewares.Middleware8.headers.framedeny=true"
- "traefik.HTTP.Middlewares.Middleware8.Headers.HostsProxyHeaders=foobar, fiibar" - "traefik.http.middlewares.Middleware8.headers.hostsproxyheaders=foobar, fiibar"
- "traefik.HTTP.Middlewares.Middleware8.Headers.IsDevelopment=true" - "traefik.http.middlewares.Middleware8.headers.isdevelopment=true"
- "traefik.HTTP.Middlewares.Middleware8.Headers.PublicKey=foobar" - "traefik.http.middlewares.Middleware8.headers.publickey=foobar"
- "traefik.HTTP.Middlewares.Middleware8.Headers.ReferrerPolicy=foobar" - "traefik.http.middlewares.Middleware8.headers.referrerpolicy=foobar"
- "traefik.HTTP.Middlewares.Middleware8.Headers.SSLForceHost=true" - "traefik.http.middlewares.Middleware8.headers.sslforcehost=true"
- "traefik.HTTP.Middlewares.Middleware8.Headers.SSLHost=foobar" - "traefik.http.middlewares.Middleware8.headers.sslhost=foobar"
- "traefik.HTTP.Middlewares.Middleware8.Headers.SSLProxyHeaders.name0=foobar" - "traefik.http.middlewares.Middleware8.headers.sslproxyheaders.name0=foobar"
- "traefik.HTTP.Middlewares.Middleware8.Headers.SSLProxyHeaders.name1=foobar" - "traefik.http.middlewares.Middleware8.headers.sslproxyheaders.name1=foobar"
- "traefik.HTTP.Middlewares.Middleware8.Headers.SSLRedirect=true" - "traefik.http.middlewares.Middleware8.headers.sslredirect=true"
- "traefik.HTTP.Middlewares.Middleware8.Headers.SSLTemporaryRedirect=true" - "traefik.http.middlewares.Middleware8.headers.ssltemporaryredirect=true"
- "traefik.HTTP.Middlewares.Middleware8.Headers.STSIncludeSubdomains=true" - "traefik.http.middlewares.Middleware8.headers.stsincludesubdomains=true"
- "traefik.HTTP.Middlewares.Middleware8.Headers.STSPreload=true" - "traefik.http.middlewares.Middleware8.headers.stspreload=true"
- "traefik.HTTP.Middlewares.Middleware8.Headers.STSSeconds=42" - "traefik.http.middlewares.Middleware8.headers.stsseconds=42"
- "traefik.HTTP.Middlewares.Middleware9.IPWhiteList.IPStrategy.Depth=42" - "traefik.http.middlewares.Middleware9.ipwhitelist.ipstrategy.depth=42"
- "traefik.HTTP.Middlewares.Middleware9.IPWhiteList.IPStrategy.ExcludedIPs=foobar, fiibar" - "traefik.http.middlewares.Middleware9.ipwhitelist.ipstrategy.excludedips=foobar, fiibar"
- "traefik.HTTP.Middlewares.Middleware9.IPWhiteList.SourceRange=foobar, fiibar" - "traefik.http.middlewares.Middleware9.ipwhitelist.sourcerange=foobar, fiibar"
- "traefik.HTTP.Middlewares.Middleware10.MaxConn.Amount=42" - "traefik.http.middlewares.Middleware10.maxconn.amount=42"
- "traefik.HTTP.Middlewares.Middleware10.MaxConn.ExtractorFunc=foobar" - "traefik.http.middlewares.Middleware10.maxconn.extractorfunc=foobar"
- "traefik.HTTP.Middlewares.Middleware11.PassTLSClientCert.Info.NotAfter=true" - "traefik.http.middlewares.Middleware11.passtlsclientcert.info.notafter=true"
- "traefik.HTTP.Middlewares.Middleware11.PassTLSClientCert.Info.NotBefore=true" - "traefik.http.middlewares.Middleware11.passtlsclientcert.info.notbefore=true"
- "traefik.HTTP.Middlewares.Middleware11.PassTLSClientCert.Info.Sans=true" - "traefik.http.middlewares.Middleware11.passtlsclientcert.info.sans=true"
- "traefik.HTTP.Middlewares.Middleware11.PassTLSClientCert.Info.Subject.Country=true" - "traefik.http.middlewares.Middleware11.passtlsclientcert.info.subject.country=true"
- "traefik.HTTP.Middlewares.Middleware11.PassTLSClientCert.Info.Subject.Province=true" - "traefik.http.middlewares.Middleware11.passtlsclientcert.info.subject.province=true"
- "traefik.HTTP.Middlewares.Middleware11.PassTLSClientCert.Info.Subject.Locality=true" - "traefik.http.middlewares.Middleware11.passtlsclientcert.info.subject.locality=true"
- "traefik.HTTP.Middlewares.Middleware11.PassTLSClientCert.Info.Subject.Organization=true" - "traefik.http.middlewares.Middleware11.passtlsclientcert.info.subject.organization=true"
- "traefik.HTTP.Middlewares.Middleware11.PassTLSClientCert.Info.Subject.CommonName=true" - "traefik.http.middlewares.Middleware11.passtlsclientcert.info.subject.commonname=true"
- "traefik.HTTP.Middlewares.Middleware11.PassTLSClientCert.Info.Subject.SerialNumber=true" - "traefik.http.middlewares.Middleware11.passtlsclientcert.info.subject.serialnumber=true"
- "traefik.HTTP.Middlewares.Middleware11.PassTLSClientCert.Info.Subject.DomainComponent=true" - "traefik.http.middlewares.Middleware11.passtlsclientcert.info.subject.domaincomponent=true"
- "traefik.HTTP.Middlewares.Middleware11.PassTLSClientCert.Info.Issuer.Country=true" - "traefik.http.middlewares.Middleware11.passtlsclientcert.info.issuer.country=true"
- "traefik.HTTP.Middlewares.Middleware11.PassTLSClientCert.Info.Issuer.Province=true" - "traefik.http.middlewares.Middleware11.passtlsclientcert.info.issuer.province=true"
- "traefik.HTTP.Middlewares.Middleware11.PassTLSClientCert.Info.Issuer.Locality=true" - "traefik.http.middlewares.Middleware11.passtlsclientcert.info.issuer.locality=true"
- "traefik.HTTP.Middlewares.Middleware11.PassTLSClientCert.Info.Issuer.Organization=true" - "traefik.http.middlewares.Middleware11.passtlsclientcert.info.issuer.organization=true"
- "traefik.HTTP.Middlewares.Middleware11.PassTLSClientCert.Info.Issuer.CommonName=true" - "traefik.http.middlewares.Middleware11.passtlsclientcert.info.issuer.commonname=true"
- "traefik.HTTP.Middlewares.Middleware11.PassTLSClientCert.Info.Issuer.SerialNumber=true" - "traefik.http.middlewares.Middleware11.passtlsclientcert.info.issuer.serialnumber=true"
- "traefik.HTTP.Middlewares.Middleware11.PassTLSClientCert.Info.Issuer.DomainComponent=true" - "traefik.http.middlewares.Middleware11.passtlsclientcert.info.issuer.domaincomponent=true"
- "traefik.HTTP.Middlewares.Middleware11.PassTLSClientCert.PEM=true" - "traefik.http.middlewares.Middleware11.passtlsclientcert.pem=true"
- "traefik.HTTP.Middlewares.Middleware12.RateLimit.ExtractorFunc=foobar" - "traefik.http.middlewares.Middleware12.ratelimit.extractorfunc=foobar"
- "traefik.HTTP.Middlewares.Middleware12.RateLimit.RateSet.Rate0.Average=42" - "traefik.http.middlewares.Middleware12.ratelimit.rateset.rate0.average=42"
- "traefik.HTTP.Middlewares.Middleware12.RateLimit.RateSet.Rate0.Burst=42" - "traefik.http.middlewares.Middleware12.ratelimit.rateset.rate0.burst=42"
- "traefik.HTTP.Middlewares.Middleware12.RateLimit.RateSet.Rate0.Period=42" - "traefik.http.middlewares.Middleware12.ratelimit.rateset.rate0.period=42"
- "traefik.HTTP.Middlewares.Middleware12.RateLimit.RateSet.Rate1.Average=42" - "traefik.http.middlewares.Middleware12.ratelimit.rateset.rate1.average=42"
- "traefik.HTTP.Middlewares.Middleware12.RateLimit.RateSet.Rate1.Burst=42" - "traefik.http.middlewares.Middleware12.ratelimit.rateset.rate1.burst=42"
- "traefik.HTTP.Middlewares.Middleware12.RateLimit.RateSet.Rate1.Period=42" - "traefik.http.middlewares.Middleware12.ratelimit.rateset.rate1.period=42"
- "traefik.HTTP.Middlewares.Middleware13.RedirectRegex.Regex=foobar" - "traefik.http.middlewares.Middleware13.redirectregex.regex=foobar"
- "traefik.HTTP.Middlewares.Middleware13.RedirectRegex.Replacement=foobar" - "traefik.http.middlewares.Middleware13.redirectregex.replacement=foobar"
- "traefik.HTTP.Middlewares.Middleware13.RedirectRegex.Permanent=true" - "traefik.http.middlewares.Middleware13.redirectregex.permanent=true"
- "traefik.HTTP.Middlewares.Middleware13b.RedirectScheme.Scheme=https" - "traefik.http.middlewares.Middleware13b.redirectscheme.scheme=https"
- "traefik.HTTP.Middlewares.Middleware13b.RedirectScheme.Port=80" - "traefik.http.middlewares.Middleware13b.redirectscheme.port=80"
- "traefik.HTTP.Middlewares.Middleware13b.RedirectScheme.Permanent=true" - "traefik.http.middlewares.Middleware13b.redirectscheme.permanent=true"
- "traefik.HTTP.Middlewares.Middleware14.ReplacePath.Path=foobar" - "traefik.http.middlewares.Middleware14.replacepath.path=foobar"
- "traefik.HTTP.Middlewares.Middleware15.ReplacePathRegex.Regex=foobar" - "traefik.http.middlewares.Middleware15.replacepathregex.regex=foobar"
- "traefik.HTTP.Middlewares.Middleware15.ReplacePathRegex.Replacement=foobar" - "traefik.http.middlewares.Middleware15.replacepathregex.replacement=foobar"
- "traefik.HTTP.Middlewares.Middleware16.Retry.Attempts=42" - "traefik.http.middlewares.Middleware16.retry.attempts=42"
- "traefik.HTTP.Middlewares.Middleware17.StripPrefix.Prefixes=foobar, fiibar" - "traefik.http.middlewares.Middleware17.stripprefix.prefixes=foobar, fiibar"
- "traefik.HTTP.Middlewares.Middleware18.StripPrefixRegex.Regex=foobar, fiibar" - "traefik.http.middlewares.Middleware18.stripprefixregex.regex=foobar, fiibar"
- "traefik.HTTP.Middlewares.Middleware19.Compress=true" - "traefik.http.middlewares.Middleware19.compress=true"
- "traefik.HTTP.Routers.Router0.EntryPoints=foobar, fiibar" - "traefik.http.routers.Router0.entrypoints=foobar, fiibar"
- "traefik.HTTP.Routers.Router0.Middlewares=foobar, fiibar" - "traefik.http.routers.Router0.middlewares=foobar, fiibar"
- "traefik.HTTP.Routers.Router0.Priority=42" - "traefik.http.routers.Router0.priority=42"
- "traefik.HTTP.Routers.Router0.Rule=foobar" - "traefik.http.routers.Router0.rule=foobar"
- "traefik.HTTP.Routers.Router0.Service=foobar" - "traefik.http.routers.Router0.service=foobar"
- "traefik.HTTP.Routers.Router0.TLS=true" - "traefik.http.routers.Router0.tls=true"
- "traefik.HTTP.Routers.Router0.TLS.options=foo" - "traefik.http.routers.Router0.tls.options=foo"
- "traefik.HTTP.Routers.Router1.EntryPoints=foobar, fiibar" - "traefik.http.routers.Router1.entrypoints=foobar, fiibar"
- "traefik.HTTP.Routers.Router1.Middlewares=foobar, fiibar" - "traefik.http.routers.Router1.middlewares=foobar, fiibar"
- "traefik.HTTP.Routers.Router1.Priority=42" - "traefik.http.routers.Router1.priority=42"
- "traefik.HTTP.Routers.Router1.Rule=foobar" - "traefik.http.routers.Router1.rule=foobar"
- "traefik.HTTP.Routers.Router1.Service=foobar" - "traefik.http.routers.Router1.service=foobar"
- "traefik.HTTP.Services.Service0.LoadBalancer.HealthCheck.Headers.name0=foobar" - "traefik.http.services.Service0.loadbalancer.healthcheck.headers.name0=foobar"
- "traefik.HTTP.Services.Service0.LoadBalancer.HealthCheck.Headers.name1=foobar" - "traefik.http.services.Service0.loadbalancer.healthcheck.headers.name1=foobar"
- "traefik.HTTP.Services.Service0.LoadBalancer.HealthCheck.Hostname=foobar" - "traefik.http.services.Service0.loadbalancer.healthcheck.hostname=foobar"
- "traefik.HTTP.Services.Service0.LoadBalancer.HealthCheck.Interval=foobar" - "traefik.http.services.Service0.loadbalancer.healthcheck.interval=foobar"
- "traefik.HTTP.Services.Service0.LoadBalancer.HealthCheck.Path=foobar" - "traefik.http.services.Service0.loadbalancer.healthcheck.path=foobar"
- "traefik.HTTP.Services.Service0.LoadBalancer.HealthCheck.Port=42" - "traefik.http.services.Service0.loadbalancer.healthcheck.port=42"
- "traefik.HTTP.Services.Service0.LoadBalancer.HealthCheck.Scheme=foobar" - "traefik.http.services.Service0.loadbalancer.healthcheck.scheme=foobar"
- "traefik.HTTP.Services.Service0.LoadBalancer.HealthCheck.Timeout=foobar" - "traefik.http.services.Service0.loadbalancer.healthcheck.timeout=foobar"
- "traefik.HTTP.Services.Service0.LoadBalancer.PassHostHeader=true" - "traefik.http.services.Service0.loadbalancer.passhostheader=true"
- "traefik.HTTP.Services.Service0.LoadBalancer.ResponseForwarding.FlushInterval=foobar" - "traefik.http.services.Service0.loadbalancer.responseforwarding.flushinterval=foobar"
- "traefik.HTTP.Services.Service0.LoadBalancer.server.Port=8080" - "traefik.http.services.Service0.loadbalancer.server.port=8080"
- "traefik.HTTP.Services.Service0.LoadBalancer.server.Scheme=foobar" - "traefik.http.services.Service0.loadbalancer.server.scheme=foobar"
- "traefik.HTTP.Services.Service0.LoadBalancer.Stickiness.CookieName=foobar" - "traefik.http.services.Service0.loadbalancer.stickiness.cookiename=foobar"
- "traefik.HTTP.Services.Service1.LoadBalancer.HealthCheck.Headers.name0=foobar" - "traefik.http.services.Service1.loadbalancer.healthcheck.headers.name0=foobar"
- "traefik.HTTP.Services.Service1.LoadBalancer.HealthCheck.Headers.name1=foobar" - "traefik.http.services.Service1.loadbalancer.healthcheck.headers.name1=foobar"
- "traefik.HTTP.Services.Service1.LoadBalancer.HealthCheck.Hostname=foobar" - "traefik.http.services.Service1.loadbalancer.healthcheck.hostname=foobar"
- "traefik.HTTP.Services.Service1.LoadBalancer.HealthCheck.Interval=foobar" - "traefik.http.services.Service1.loadbalancer.healthcheck.interval=foobar"
- "traefik.HTTP.Services.Service1.LoadBalancer.HealthCheck.Path=foobar" - "traefik.http.services.Service1.loadbalancer.healthcheck.path=foobar"
- "traefik.HTTP.Services.Service1.LoadBalancer.HealthCheck.Port=42" - "traefik.http.services.Service1.loadbalancer.healthcheck.port=42"
- "traefik.HTTP.Services.Service1.LoadBalancer.HealthCheck.Scheme=foobar" - "traefik.http.services.Service1.loadbalancer.healthcheck.scheme=foobar"
- "traefik.HTTP.Services.Service1.LoadBalancer.HealthCheck.Timeout=foobar" - "traefik.http.services.Service1.loadbalancer.healthcheck.timeout=foobar"
- "traefik.HTTP.Services.Service1.LoadBalancer.PassHostHeader=true" - "traefik.http.services.Service1.loadbalancer.passhostheader=true"
- "traefik.HTTP.Services.Service1.LoadBalancer.ResponseForwarding.FlushInterval=foobar" - "traefik.http.services.Service1.loadbalancer.responseforwarding.flushinterval=foobar"
- "traefik.HTTP.Services.Service1.LoadBalancer.server.Port=8080" - "traefik.http.services.Service1.loadbalancer.server.port=8080"
- "traefik.HTTP.Services.Service1.LoadBalancer.server.Scheme=foobar" - "traefik.http.services.Service1.loadbalancer.server.scheme=foobar"
- "traefik.TCP.Routers.Router0.Rule=foobar" - "traefik.tcp.routers.Router0.rule=foobar"
- "traefik.TCP.Routers.Router0.EntryPoints=foobar, fiibar" - "traefik.tcp.routers.Router0.entrypoints=foobar, fiibar"
- "traefik.TCP.Routers.Router0.Service=foobar" - "traefik.tcp.routers.Router0.service=foobar"
- "traefik.TCP.Routers.Router0.TLS.Passthrough=false" - "traefik.tcp.routers.Router0.tls.passthrough=false"
- "traefik.TCP.Routers.Router0.TLS.options=bar" - "traefik.tcp.routers.Router0.tls.options=bar"
- "traefik.TCP.Routers.Router1.Rule=foobar" - "traefik.tcp.routers.Router1.rule=foobar"
- "traefik.TCP.Routers.Router1.EntryPoints=foobar, fiibar" - "traefik.tcp.routers.Router1.entrypoints=foobar, fiibar"
- "traefik.TCP.Routers.Router1.Service=foobar" - "traefik.tcp.routers.Router1.service=foobar"
- "traefik.TCP.Routers.Router1.TLS.Passthrough=false" - "traefik.tcp.routers.Router1.tls.passthrough=false"
- "traefik.TCP.Routers.Router1.TLS.options=foobar" - "traefik.tcp.routers.Router1.tls.options=foobar"
- "traefik.TCP.Services.Service0.LoadBalancer.server.Port=42" - "traefik.tcp.services.Service0.loadbalancer.server.port=42"
- "traefik.TCP.Services.Service1.LoadBalancer.server.Port=42" - "traefik.tcp.services.Service1.loadbalancer.server.port=42"

View file

@ -1,254 +1,232 @@
[Global] [global]
CheckNewVersion = true checkNewVersion = true
SendAnonymousUsage = true sendAnonymousUsage = true
[ServersTransport] [serversTransport]
InsecureSkipVerify = true insecureSkipVerify = true
RootCAs = ["foobar", "foobar"] rootCAs = ["foobar", "foobar"]
MaxIdleConnsPerHost = 42 maxIdleConnsPerHost = 42
[ServersTransport.ForwardingTimeouts] [serversTransport.forwardingTimeouts]
DialTimeout = 42 dialTimeout = 42
ResponseHeaderTimeout = 42 responseHeaderTimeout = 42
IdleConnTimeout = 5 idleConnTimeout = 42
[EntryPoints] [entryPoints]
[entryPoints.EntryPoint0]
address = "foobar"
[entryPoints.EntryPoint0.transport]
[entryPoints.EntryPoint0.transport.lifeCycle]
requestAcceptGraceTimeout = 42
graceTimeOut = 42
[entryPoints.EntryPoint0.transport.respondingTimeouts]
readTimeout = 42
writeTimeout = 42
idleTimeout = 42
[entryPoints.EntryPoint0.proxyProtocol]
insecure = true
trustedIPs = ["foobar", "foobar"]
[entryPoints.EntryPoint0.forwardedHeaders]
insecure = true
trustedIPs = ["foobar", "foobar"]
[EntryPoints.EntryPoint0] [providers]
Address = "foobar" providersThrottleDuration = 42
[EntryPoints.EntryPoint0.Transport] [providers.docker]
[EntryPoints.EntryPoint0.Transport.LifeCycle] constraints = "foobar"
RequestAcceptGraceTimeout = 42 watch = true
GraceTimeOut = 42 endpoint = "foobar"
[EntryPoints.EntryPoint0.Transport.RespondingTimeouts] defaultRule = "foobar"
ReadTimeout = 42 exposedByDefault = true
WriteTimeout = 42 useBindPortIP = true
IdleTimeout = 42 swarmMode = true
[EntryPoints.EntryPoint0.ProxyProtocol] network = "foobar"
Insecure = true swarmModeRefreshSeconds = 42
TrustedIPs = ["foobar", "foobar"] [providers.docker.tls]
[EntryPoints.EntryPoint0.ForwardedHeaders] ca = "foobar"
Insecure = true caOptional = true
TrustedIPs = ["foobar", "foobar"] cert = "foobar"
key = "foobar"
insecureSkipVerify = true
[providers.file]
directory = "foobar"
watch = true
filename = "foobar"
debugLogGeneratedTemplate = true
traefikFile = "foobar"
[providers.marathon]
constraints = "foobar"
trace = true
watch = true
endpoint = "foobar"
defaultRule = "foobar"
exposedByDefault = true
dcosToken = "foobar"
dialerTimeout = 42
responseHeaderTimeout = 42
tlsHandshakeTimeout = 42
keepAlive = 42
forceTaskHostname = true
respectReadinessChecks = true
[providers.marathon.tls]
ca = "foobar"
caOptional = true
cert = "foobar"
key = "foobar"
insecureSkipVerify = true
[providers.marathon.basic]
httpBasicAuthUser = "foobar"
httpBasicPassword = "foobar"
[providers.kubernetes]
endpoint = "foobar"
token = "foobar"
certAuthFilePath = "foobar"
disablePassHostHeaders = true
namespaces = ["foobar", "foobar"]
labelSelector = "foobar"
ingressClass = "foobar"
[providers.kubernetes.ingressEndpoint]
ip = "foobar"
hostname = "foobar"
publishedService = "foobar"
[providers.kubernetesCRD]
endpoint = "foobar"
token = "foobar"
certAuthFilePath = "foobar"
disablePassHostHeaders = true
namespaces = ["foobar", "foobar"]
labelSelector = "foobar"
ingressClass = "foobar"
[providers.rest]
entryPoint = "foobar"
[providers.rancher]
constraints = "foobar"
watch = true
defaultRule = "foobar"
exposedByDefault = true
enableServiceHealthFilter = true
refreshSeconds = 42
intervalPoll = true
prefix = "foobar"
[Providers] [api]
ProvidersThrottleDuration = 42 entryPoint = "foobar"
dashboard = true
middlewares = ["foobar", "foobar"]
[api.statistics]
recentErrors = 42
[Providers.Docker] [metrics]
Watch = true [metrics.prometheus]
Endpoint = "foobar" buckets = [42.0, 42.0]
DefaultRule = "foobar" entryPoint = "foobar"
ExposedByDefault = true middlewares = ["foobar", "foobar"]
UseBindPortIP = true [metrics.dataDog]
SwarmMode = true address = "foobar"
Network = "foobar" pushInterval = "10s"
SwarmModeRefreshSeconds = 42 [metrics.statsD]
Constraints = "foobar" address = "foobar"
pushInterval = "10s"
[metrics.influxDB]
address = "foobar"
protocol = "foobar"
pushInterval = "10s"
database = "foobar"
retentionPolicy = "foobar"
username = "foobar"
password = "foobar"
[Providers.Docker.TLS] [ping]
CA = "foobar" entryPoint = "foobar"
CAOptional = true middlewares = ["foobar", "foobar"]
Cert = "foobar"
Key = "foobar"
InsecureSkipVerify = true
[Providers.File] [log]
Directory = "foobar" level = "foobar"
Watch = true filePath = "foobar"
Filename = "foobar" format = "foobar"
DebugLogGeneratedTemplate = true
TraefikFile = "foobar"
[Providers.Marathon] [accessLog]
Trace = true filePath = "foobar"
Watch = true format = "foobar"
Endpoint = "foobar" bufferingSize = 42
DefaultRule = "foobar" [accessLog.filters]
ExposedByDefault = true statusCodes = ["foobar", "foobar"]
DCOSToken = "foobar" retryAttempts = true
DialerTimeout = 42 minDuration = 42
ResponseHeaderTimeout = 42 [accessLog.fields]
TLSHandshakeTimeout = 42 defaultMode = "foobar"
KeepAlive = 42 [accessLog.fields.names]
ForceTaskHostname = true
RespectReadinessChecks = true
Constraints = "foobar"
[Providers.Marathon.TLS]
CA = "foobar"
CAOptional = true
Cert = "foobar"
Key = "foobar"
InsecureSkipVerify = true
[Providers.Marathon.Basic]
HTTPBasicAuthUser = "foobar"
HTTPBasicPassword = "foobar"
[Providers.Kubernetes]
Endpoint = "foobar"
Token = "foobar"
CertAuthFilePath = "foobar"
DisablePassHostHeaders = true
Namespaces = ["foobar", "foobar"]
LabelSelector = "foobar"
IngressClass = "foobar"
[Providers.Kubernetes.IngressEndpoint]
IP = "foobar"
Hostname = "foobar"
PublishedService = "foobar"
[Providers.KubernetesCRD]
Endpoint = "foobar"
Token = "foobar"
CertAuthFilePath = "foobar"
DisablePassHostHeaders = true
Namespaces = ["foobar", "foobar"]
LabelSelector = "foobar"
IngressClass = "foobar"
[Providers.Rest]
EntryPoint = "foobar"
[Providers.Rancher]
Watch = true
DefaultRule = "foobar"
ExposedByDefault = true
EnableServiceHealthFilter = true
RefreshSeconds = 42
IntervalPoll = true
Prefix = "foobar"
Constraints = "foobar"
[API]
EntryPoint = "foobar"
Dashboard = true
Middlewares = ["foobar", "foobar"]
[API.Statistics]
RecentErrors = 42
[Metrics]
[Metrics.Prometheus]
Buckets = [42.0, 42.0]
EntryPoint = "foobar"
Middlewares = ["foobar", "foobar"]
[Metrics.Datadog]
Address = "foobar"
PushInterval = "10s"
[Metrics.StatsD]
Address = "foobar"
PushInterval = "10s"
[Metrics.InfluxDB]
Address = "foobar"
Protocol = "foobar"
PushInterval = "10s"
Database = "foobar"
RetentionPolicy = "foobar"
Username = "foobar"
Password = "foobar"
[Ping]
EntryPoint = "foobar"
Middlewares = ["foobar", "foobar"]
[Log]
Level = "foobar"
FilePath = "foobar"
Format = "foobar"
[AccessLog]
FilePath = "foobar"
Format = "foobar"
BufferingSize = 42
[AccessLog.Filters]
StatusCodes = ["foobar", "foobar"]
RetryAttempts = true
MinDuration = 42
[AccessLog.Fields]
DefaultMode = "foobar"
[AccessLog.Fields.Names]
name0 = "foobar" name0 = "foobar"
name1 = "foobar" name1 = "foobar"
[AccessLog.Fields.Headers] [accessLog.fields.headers]
DefaultMode = "foobar" defaultMode = "foobar"
[AccessLog.Fields.Headers.Names] [accessLog.fields.headers.names]
name0 = "foobar" name0 = "foobar"
name1 = "foobar" name1 = "foobar"
[Tracing] [tracing]
ServiceName = "foobar" serviceName = "foobar"
SpanNameLimit = 42 spanNameLimit = 42
[tracing.jaeger]
samplingServerURL = "foobar"
samplingType = "foobar"
samplingParam = 42.0
localAgentHostPort = "foobar"
gen128Bit = true
propagation = "foobar"
traceContextHeaderName = "foobar"
[tracing.zipkin]
httpEndpoint = "foobar"
sameSpan = true
id128Bit = true
debug = true
sampleRate = 42.0
[tracing.dataDog]
localAgentHostPort = "foobar"
globalTag = "foobar"
debug = true
prioritySampling = true
traceIDHeaderName = "foobar"
parentIDHeaderName = "foobar"
samplingPriorityHeaderName = "foobar"
bagagePrefixHeaderName = "foobar"
[tracing.instana]
localAgentHost = "foobar"
localAgentPort = 42
logLevel = "foobar"
[tracing.haystack]
localAgentHost = "foobar"
localAgentPort = 42
globalTag = "foobar"
traceIDHeaderName = "foobar"
parentIDHeaderName = "foobar"
spanIDHeaderName = "foobar"
[Tracing.Jaeger] [hostResolver]
SamplingServerURL = "foobar" cnameFlattening = true
SamplingType = "foobar" resolvConfig = "foobar"
SamplingParam = 42.0 resolvDepth = 42
LocalAgentHostPort = "foobar"
Gen128Bit = true
Propagation = "foobar"
TraceContextHeaderName = "foobar"
[Tracing.Zipkin] [acme]
HTTPEndpoint = "foobar" email = "foobar"
SameSpan = true acmeLogging = true
ID128Bit = true caServer = "foobar"
Debug = true storage = "foobar"
SampleRate = 42.0 entryPoint = "foobar"
keyType = "foobar"
onHostRule = true
[acme.dnsChallenge]
provider = "foobar"
delayBeforeCheck = 42
resolvers = ["foobar", "foobar"]
disablePropagationCheck = true
[acme.httpChallenge]
entryPoint = "foobar"
[acme.tlsChallenge]
[Tracing.DataDog] [[acme.domains]]
LocalAgentHostPort = "foobar" main = "foobar"
GlobalTag = "foobar" sans = ["foobar", "foobar"]
Debug = true
PrioritySampling = true
TraceIDHeaderName = "foobar"
ParentIDHeaderName = "foobar"
SamplingPriorityHeaderName = "foobar"
BagagePrefixHeaderName = "foobar"
[Tracing.Instana] [[acme.domains]]
LocalAgentHost = "foobar" main = "foobar"
LocalAgentPort = 42 sans = ["foobar", "foobar"]
LogLevel = "foobar"
[Tracing.Haystack]
LocalAgentHost = "foobar"
LocalAgentPort = 42
GlobalTag = "foobar"
ParentIDHeaderName = "foobar"
SpanIDHeaderName = "foobar"
TraceIDHeaderName = "foobar"
[HostResolver]
CnameFlattening = true
ResolvConfig = "foobar"
ResolvDepth = 42
[ACME]
Email = "foobar"
ACMELogging = true
CAServer = "foobar"
Storage = "foobar"
EntryPoint = "foobar"
KeyType = "foobar"
OnHostRule = true
[ACME.DNSChallenge]
Provider = "foobar"
DelayBeforeCheck = 42
Resolvers = ["foobar", "foobar"]
DisablePropagationCheck = true
[ACME.HTTPChallenge]
EntryPoint = "foobar"
[ACME.TLSChallenge]
[[ACME.Domains]]
Main = "foobar"
SANs = ["foobar", "foobar"]
[[ACME.Domains]]
Main = "foobar"
SANs = ["foobar", "foobar"]

View file

@ -1,234 +1,238 @@
global: global:
checknewversion: true checkNewVersion: true
sendanonymoususage: true sendAnonymousUsage: true
serverstransport: serversTransport:
insecureskipverify: true insecureSkipVerify: true
rootcas: rootCAs:
- foobar - foobar
- foobar - foobar
maxidleconnsperhost: 42 maxIdleConnsPerHost: 42
forwardingtimeouts: forwardingTimeouts:
dialtimeout: 42000000000 dialTimeout: 42000000000
responseheadertimeout: 42000000000 responseHeaderTimeout: 42000000000
entrypoints: idleConnTimeout: 42000000000
entryPoints:
EntryPoint0: EntryPoint0:
address: foobar address: foobar
transport: transport:
lifecycle: lifeCycle:
requestacceptgracetimeout: 42000000000 requestAcceptGraceTimeout: 42000000000
gracetimeout: 42000000000 graceTimeOut: 42000000000
respondingtimeouts: respondingTimeouts:
readtimeout: 42000000000 readTimeout: 42000000000
writetimeout: 42000000000 writeTimeout: 42000000000
idletimeout: 42000000000 idleTimeout: 42000000000
proxyprotocol: proxyProtocol:
insecure: true insecure: true
trustedips: trustedIPs:
- foobar - foobar
- foobar - foobar
forwardedheaders: forwardedHeaders:
insecure: true insecure: true
trustedips: trustedIPs:
- foobar - foobar
- foobar - foobar
providers: providers:
providersthrottleduration: 42000000000 providersThrottleDuration: 42000000000
docker: docker:
constraints: foobar constraints: foobar
watch: true watch: true
endpoint: foobar endpoint: foobar
defaultrule: foobar defaultRule: foobar
tls: tls:
ca: foobar ca: foobar
caoptional: true caOptional: true
cert: foobar cert: foobar
key: foobar key: foobar
insecureskipverify: true insecureSkipVerify: true
exposedbydefault: true exposedByDefault: true
usebindportip: true useBindPortIP: true
swarmmode: true swarmMode: true
network: foobar network: foobar
swarmmoderefreshseconds: 42000000000 swarmModeRefreshSeconds: 42000000000
file: file:
directory: foobar directory: foobar
watch: true watch: true
filename: foobar filename: foobar
debugloggeneratedtemplate: true debugLogGeneratedTemplate: true
traefikfile: foobar traefikFile: foobar
marathon: marathon:
constraints: foobar constraints: foobar
trace: true trace: true
watch: true watch: true
endpoint: foobar endpoint: foobar
defaultrule: foobar defaultRule: foobar
exposedbydefault: true exposedByDefault: true
dcostoken: foobar dcosToken: foobar
tls: tls:
ca: foobar ca: foobar
caoptional: true caOptional: true
cert: foobar cert: foobar
key: foobar key: foobar
insecureskipverify: true insecureSkipVerify: true
dialertimeout: 42000000000 dialerTimeout: 42000000000
responseheadertimeout: 42000000000 responseHeaderTimeout: 42000000000
tlshandshaketimeout: 42000000000 tlsHandshakeTimeout: 42000000000
keepalive: 42000000000 keepAlive: 42000000000
forcetaskhostname: true forceTaskHostname: true
basic: basic:
httpbasicauthuser: foobar httpBasicAuthUser: foobar
httpbasicpassword: foobar httpBasicPassword: foobar
respectreadinesschecks: true respectReadinessChecks: true
kubernetes: kubernetes:
endpoint: foobar endpoint: foobar
token: foobar token: foobar
certauthfilepath: foobar certAuthFilePath: foobar
disablepasshostheaders: true disablePassHostHeaders: true
namespaces: namespaces:
- foobar - foobar
- foobar - foobar
labelselector: foobar labelSelector: foobar
ingressclass: foobar ingressClass: foobar
ingressendpoint: ingressEndpoint:
ip: foobar ip: foobar
hostname: foobar hostname: foobar
publishedservice: foobar publishedService: foobar
kubernetescrd: kubernetesCRD:
endpoint: foobar endpoint: foobar
token: foobar token: foobar
certauthfilepath: foobar certAuthFilePath: foobar
disablepasshostheaders: true disablePassHostHeaders: true
namespaces: namespaces:
- foobar - foobar
- foobar - foobar
labelselector: foobar labelSelector: foobar
ingressclass: foobar ingressClass: foobar
rest: rest:
entrypoint: foobar entryPoint: foobar
rancher: rancher:
constraints: foobar constraints: foobar
watch: true watch: true
defaultrule: foobar defaultRule: foobar
exposedbydefault: true exposedByDefault: true
enableservicehealthfilter: true enableServiceHealthFilter: true
refreshseconds: 42 refreshSeconds: 42
intervalpoll: true intervalPoll: true
prefix: foobar prefix: foobar
api: api:
entrypoint: foobar entryPoint: foobar
dashboard: true dashboard: true
debug: false
statistics: statistics:
recenterrors: 42 recentErrors: 42
middlewares: middlewares:
- foobar - foobar
- foobar - foobar
dashboardassets: null
metrics: metrics:
prometheus: prometheus:
buckets: buckets:
- 42 - 42
- 42 - 42
entrypoint: foobar entryPoint: foobar
middlewares: middlewares:
- foobar - foobar
- foobar - foobar
datadog: dataDog:
address: foobar address: foobar
pushinterval: 10000000000 pushInterval: 10000000000
statsd: statsD:
address: foobar address: foobar
pushinterval: 10000000000 pushInterval: 10000000000
influxdb: influxDB:
address: foobar address: foobar
protocol: foobar protocol: foobar
pushinterval: 10000000000 pushInterval: 10000000000
database: foobar database: foobar
retentionpolicy: foobar retentionPolicy: foobar
username: foobar username: foobar
password: foobar password: foobar
ping: ping:
entrypoint: foobar entryPoint: foobar
middlewares: middlewares:
- foobar - foobar
- foobar - foobar
log: log:
level: foobar level: foobar
filepath: foobar filePath: foobar
format: foobar format: foobar
accesslog: accessLog:
filepath: foobar filePath: foobar
format: foobar format: foobar
filters: filters:
statuscodes: statusCodes:
- foobar - foobar
- foobar - foobar
retryattempts: true retryAttempts: true
minduration: 42000000000 minDuration: 42000000000
fields: fields:
defaultmode: foobar defaultMode: foobar
names: names:
name0: foobar name0: foobar
name1: foobar name1: foobar
headers: headers:
defaultmode: foobar defaultMode: foobar
names: names:
name0: foobar name0: foobar
name1: foobar name1: foobar
bufferingsize: 42 bufferingSize: 42
tracing: tracing:
backend: foobar serviceName: foobar
servicename: foobar spanNameLimit: 42
spannamelimit: 42
jaeger: jaeger:
samplingserverurl: foobar samplingServerURL: foobar
samplingtype: foobar samplingType: foobar
samplingparam: 42 samplingParam: 42
localagenthostport: foobar localAgentHostPort: foobar
gen128bit: true gen128Bit: true
propagation: foobar propagation: foobar
tracecontextheadername: foobar traceContextHeaderName: foobar
zipkin: zipkin:
httpendpoint: foobar httpEndpoint: foobar
samespan: true sameSpan: true
id128bit: true id128Bit: true
debug: true debug: true
samplerate: 42 sampleRate: 42
datadog: dataDog:
localagenthostport: foobar localAgentHostPort: foobar
globaltag: foobar globalTag: foobar
debug: true debug: true
prioritysampling: true prioritySampling: true
traceidheadername: foobar traceIDHeaderName: foobar
parentidheadername: foobar parentIDHeaderName: foobar
samplingpriorityheadername: foobar samplingPriorityHeaderName: foobar
bagageprefixheadername: foobar bagagePrefixHeaderName: foobar
instana: instana:
localagenthost: foobar localAgentHost: foobar
localagentport: 42 localAgentPort: 42
loglevel: foobar logLevel: foobar
haystack: null haystack:
hostresolver: localAgentHost: foobar
cnameflattening: true localAgentPort: 42
resolvconfig: foobar globalTag: foobar
resolvdepth: 42 traceIDHeaderName: foobar
parentIDHeaderName: foobar
spanIDHeaderName: foobar
hostResolver:
cnameFlattening: true
resolvConfig: foobar
resolvDepth: 42
acme: acme:
email: foobar email: foobar
acmelogging: true acmeLogging: true
caserver: foobar caServer: foobar
storage: foobar storage: foobar
entrypoint: foobar entryPoint: foobar
keytype: foobar keyType: foobar
onhostrule: true onHostRule: true
dnschallenge: dnsChallenge:
provider: foobar provider: foobar
delaybeforecheck: 42000000000 delayBeforeCheck: 42000000000
resolvers: resolvers:
- foobar - foobar
- foobar - foobar
disablepropagationcheck: true disablePropagationCheck: true
httpchallenge: httpChallenge:
entrypoint: foobar entryPoint: foobar
tlschallenge: {} tlsChallenge: {}
domains: domains:
- main: foobar - main: foobar
sans: sans:

View file

@ -3,7 +3,7 @@
Opening Connections for Incoming Requests Opening Connections for Incoming Requests
{: .subtitle } {: .subtitle }
![EntryPoints](../assets/img/entrypoints.png) ![entryPoints](../assets/img/entrypoints.png)
EntryPoints are the network entry points into Traefik. EntryPoints are the network entry points into Traefik.
They define the port which will receive the requests (whether HTTP or TCP). They define the port which will receive the requests (whether HTTP or TCP).
@ -12,17 +12,27 @@ They define the port which will receive the requests (whether HTTP or TCP).
??? example "Port 80 only" ??? example "Port 80 only"
```toml ```toml tab="File (TOML)"
[entryPoints] [entryPoints]
[entryPoints.web] [entryPoints.web]
address = ":80" address = ":80"
``` ```
```yaml tab="File (YAML)"
entryPoints:
web:
address: ":80"
```
```ini tab="CLI"
--entryPoints.web.address=:80
```
We define an `entrypoint` called `web` that will listen on port `80`. We define an `entrypoint` called `web` that will listen on port `80`.
??? example "Port 80 & 443" ??? example "Port 80 & 443"
```toml ```toml tab="File (TOML)"
[entryPoints] [entryPoints]
[entryPoints.web] [entryPoints.web]
address = ":80" address = ":80"
@ -31,6 +41,20 @@ They define the port which will receive the requests (whether HTTP or TCP).
address = ":443" address = ":443"
``` ```
```yaml tab="File (YAML)"
entryPoints:
web:
address: ":80"
web-secure:
address: ":443"
```
```ini tab="CLI"
--entryPoints.web.address=:80
--entryPoints.web-secure.address=:443
```
- Two entrypoints are defined: one called `web`, and the other called `web-secure`. - Two entrypoints are defined: one called `web`, and the other called `web-secure`.
- `web` listens on port `80`, and `web-secure` on port `443`. - `web` listens on port `80`, and `web-secure` on port `443`.
@ -43,38 +67,63 @@ You can define them using a toml file, CLI arguments, or a key-value store.
See the complete reference for the list of available options: See the complete reference for the list of available options:
```toml tab="File" ```toml tab="File (TOML)"
[entryPoints] [entryPoints]
[entryPoints.EntryPoint0] [entryPoints.EntryPoint0]
Address = ":8888" address = ":8888"
[entryPoints.EntryPoint0.Transport] [entryPoints.EntryPoint0.transport]
[entryPoints.EntryPoint0.Transport.LifeCycle] [entryPoints.EntryPoint0.transport.lifeCycle]
RequestAcceptGraceTimeout = 42 requestAcceptGraceTimeout = 42
GraceTimeOut = 42 graceTimeOut = 42
[entryPoints.EntryPoint0.Transport.RespondingTimeouts] [entryPoints.EntryPoint0.transport.respondingTimeouts]
ReadTimeout = 42 readTimeout = 42
WriteTimeout = 42 writeTimeout = 42
IdleTimeout = 42 idleTimeout = 42
[entryPoints.EntryPoint0.ProxyProtocol] [entryPoints.EntryPoint0.proxyProtocol]
Insecure = true insecure = true
TrustedIPs = ["foobar", "foobar"] trustedIPs = ["foobar", "foobar"]
[entryPoints.EntryPoint0.ForwardedHeaders] [entryPoints.EntryPoint0.forwardedHeaders]
Insecure = true insecure = true
TrustedIPs = ["foobar", "foobar"] trustedIPs = ["foobar", "foobar"]
```
```yaml tab="File (YAML)"
entryPoints:
EntryPoint0:
address: ":8888"
transport:
lifeCycle:
requestAcceptGraceTimeout: 42
graceTimeOut: 42
respondingTimeouts:
readTimeout: 42
writeTimeout: 42
idleTimeout: 42
proxyProtocol:
insecure: true
trustedIPs:
- "foobar"
- "foobar"
forwardedHeaders:
insecure: true
trustedIPs:
- "foobar"
- "foobar"
``` ```
```ini tab="CLI" ```ini tab="CLI"
--entryPoints.EntryPoint0.Address=:8888 --entryPoints.EntryPoint0.address=:8888
--entryPoints.EntryPoint0.Transport.LifeCycle.RequestAcceptGraceTimeout=42 --entryPoints.EntryPoint0.transport.lifeCycle.requestAcceptGraceTimeout=42
--entryPoints.EntryPoint0.Transport.LifeCycle.GraceTimeOut=42 --entryPoints.EntryPoint0.transport.lifeCycle.graceTimeOut=42
--entryPoints.EntryPoint0.Transport.RespondingTimeouts.ReadTimeout=42 --entryPoints.EntryPoint0.transport.respondingTimeouts.readTimeout=42
--entryPoints.EntryPoint0.Transport.RespondingTimeouts.WriteTimeout=42 --entryPoints.EntryPoint0.transport.respondingTimeouts.writeTimeout=42
--entryPoints.EntryPoint0.Transport.RespondingTimeouts.IdleTimeout=42 --entryPoints.EntryPoint0.transport.respondingTimeouts.idleTimeout=42
--entryPoints.EntryPoint0.ProxyProtocol.Insecure=true --entryPoints.EntryPoint0.proxyProtocol.insecure=true
--entryPoints.EntryPoint0.ProxyProtocol.TrustedIPs=foobar,foobar --entryPoints.EntryPoint0.proxyProtocol.trustedIPs=foobar,foobar
--entryPoints.EntryPoint0.ForwardedHeaders.Insecure=true --entryPoints.EntryPoint0.forwardedHeaders.insecure=true
--entryPoints.EntryPoint0.ForwardedHeaders.TrustedIPs=foobar,foobar --entryPoints.EntryPoint0.forwardedHeaders.trustedIPs=foobar,foobar
``` ```
## ProxyProtocol ## ProxyProtocol
@ -83,7 +132,7 @@ Traefik supports [ProxyProtocol](https://www.haproxy.org/download/1.8/doc/proxy-
??? example "Enabling Proxy Protocol with Trusted IPs" ??? example "Enabling Proxy Protocol with Trusted IPs"
```toml ```toml tab="File (TOML)"
[entryPoints] [entryPoints]
[entryPoints.web] [entryPoints.web]
address = ":80" address = ":80"
@ -92,6 +141,21 @@ Traefik supports [ProxyProtocol](https://www.haproxy.org/download/1.8/doc/proxy-
trustedIPs = ["127.0.0.1/32", "192.168.1.7"] trustedIPs = ["127.0.0.1/32", "192.168.1.7"]
``` ```
```yaml tab="File (YAML)"
entryPoints:
web:
address: ":80"
proxyProtocol
trustedIPs:
- "127.0.0.1/32"
- "192.168.1.7"
```
```ini tab="CLI"
--entryPoints.web.address=:80
--entryPoints.web.proxyProtocol.trustedIPs=127.0.0.1/32,192.168.1.7
```
IPs in `trustedIPs` only will lead to remote client address replacement: Declare load-balancer IPs or CIDR range here. IPs in `trustedIPs` only will lead to remote client address replacement: Declare load-balancer IPs or CIDR range here.
??? example "Insecure Mode -- Testing Environment Only" ??? example "Insecure Mode -- Testing Environment Only"
@ -99,7 +163,7 @@ Traefik supports [ProxyProtocol](https://www.haproxy.org/download/1.8/doc/proxy-
In a test environments, you can configure Traefik to trust every incoming connection. In a test environments, you can configure Traefik to trust every incoming connection.
Doing so, every remote client address will be replaced (`trustedIPs` won't have any effect) Doing so, every remote client address will be replaced (`trustedIPs` won't have any effect)
```toml ```toml tab="File (TOML)"
[entryPoints] [entryPoints]
[entryPoints.web] [entryPoints.web]
address = ":80" address = ":80"
@ -108,6 +172,19 @@ Traefik supports [ProxyProtocol](https://www.haproxy.org/download/1.8/doc/proxy-
insecure = true insecure = true
``` ```
```yaml tab="File (YAML)"
entryPoints:
web:
address: ":80"
proxyProtocol:
insecure: true
```
```ini tab="CLI"
--entryPoints.web.address=:80
--entryPoints.web.proxyProtocol.insecure
```
!!! warning "Queuing Traefik behind Another Load Balancer" !!! warning "Queuing Traefik behind Another Load Balancer"
When queuing Traefik behind another load-balancer, make sure to configure Proxy Protocol on both sides. When queuing Traefik behind another load-balancer, make sure to configure Proxy Protocol on both sides.
@ -119,7 +196,7 @@ You can configure Traefik to trust the forwarded headers information (`X-Forward
??? example "Trusting Forwarded Headers from specific IPs" ??? example "Trusting Forwarded Headers from specific IPs"
```toml ```toml tab="File (TOML)"
[entryPoints] [entryPoints]
[entryPoints.web] [entryPoints.web]
address = ":80" address = ":80"
@ -128,9 +205,24 @@ You can configure Traefik to trust the forwarded headers information (`X-Forward
trustedIPs = ["127.0.0.1/32", "192.168.1.7"] trustedIPs = ["127.0.0.1/32", "192.168.1.7"]
``` ```
```yaml tab="File (YAML)"
entryPoints:
web:
address: ":80"
forwardedHeaders
trustedIPs:
- "127.0.0.1/32"
- "192.168.1.7"
```
```ini tab="CLI"
--entryPoints.web.address=:80
--entryPoints.web.forwardedHeaders.trustedIPs=127.0.0.1/32,192.168.1.7
```
??? example "Insecure Mode -- Always Trusting Forwarded Headers" ??? example "Insecure Mode -- Always Trusting Forwarded Headers"
```toml ```toml tab="File (TOML)"
[entryPoints] [entryPoints]
[entryPoints.web] [entryPoints.web]
address = ":80" address = ":80"
@ -138,3 +230,16 @@ You can configure Traefik to trust the forwarded headers information (`X-Forward
[entryPoints.web.forwardedHeaders] [entryPoints.web.forwardedHeaders]
insecure = true insecure = true
``` ```
```yaml tab="File (YAML)"
entryPoints:
web:
address: ":80"
forwardedHeaders:
insecure: true
```
```ini tab="CLI"
--entryPoints.web.address=:80
--entryPoints.web.forwardedHeaders.insecure
```

View file

@ -38,10 +38,11 @@ Static configuration:
``` ```
```yaml tab="YAML" ```yaml tab="YAML"
entrypoints: entryPoints:
web: web:
# Listen on port 8081 for incoming requests # Listen on port 8081 for incoming requests
address: :8081 address: :8081
providers: providers:
# Enable the file provider to define routers / middlewares / services in a file # Enable the file provider to define routers / middlewares / services in a file
file: {} file: {}
@ -63,13 +64,13 @@ Dynamic configuration:
[http.middlewares] [http.middlewares]
# Define an authentication mechanism # Define an authentication mechanism
[http.middlewares.test-user.basicauth] [http.middlewares.test-user.basicAuth]
users = ["test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/"] users = ["test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/"]
[http.services] [http.services]
# Define how to reach an existing service on our infrastructure # Define how to reach an existing service on our infrastructure
[http.services.whoami.loadbalancer] [http.services.whoami.loadBalancer]
[[http.services.whoami.loadbalancer.servers]] [[http.services.whoami.loadBalancer.servers]]
url = "http://private/whoami-service" url = "http://private/whoami-service"
``` ```
@ -85,16 +86,18 @@ http:
- test-user - test-user
# If the rule matches, forward to the whoami service (declared below) # If the rule matches, forward to the whoami service (declared below)
service: whoami service: whoami
middlewares: middlewares:
# Define an authentication mechanism # Define an authentication mechanism
test-user: test-user:
basicAuth: basicAuth:
users: users:
- test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/ - test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/
services: services:
# Define how to reach an existing service on our infrastructure # Define how to reach an existing service on our infrastructure
whoami: whoami:
loadbalancer: loadBalancer:
servers: servers:
- url: http://private/whoami-service - url: http://private/whoami-service
``` ```
@ -125,7 +128,7 @@ http:
``` ```
```yaml tab="YAML" ```yaml tab="YAML"
entrypoints: entryPoints:
web: web:
# Listen on port 8081 for incoming requests # Listen on port 8081 for incoming requests
address: :8081 address: :8081
@ -150,13 +153,13 @@ http:
[http.middlewares] [http.middlewares]
# Define an authentication mechanism # Define an authentication mechanism
[http.middlewares.test-user.basicauth] [http.middlewares.test-user.basicAuth]
users = ["test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/"] users = ["test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/"]
[http.services] [http.services]
# Define how to reach an existing service on our infrastructure # Define how to reach an existing service on our infrastructure
[http.services.whoami.loadbalancer] [http.services.whoami.loadBalancer]
[[http.services.whoami.loadbalancer.servers]] [[http.services.whoami.loadBalancer.servers]]
url = "http://private/whoami-service" url = "http://private/whoami-service"
[tcp] [tcp]
@ -167,14 +170,15 @@ http:
[tcp.routers.to-whoami-tcp.tls] [tcp.routers.to-whoami-tcp.tls]
[tcp.services] [tcp.services]
[tcp.services.whoami-tcp.loadbalancer] [tcp.services.whoami-tcp.loadBalancer]
[[tcp.services.whoami-tcp.loadbalancer.servers]] [[tcp.services.whoami-tcp.loadBalancer.servers]]
address = "xx.xx.xx.xx:xx" address = "xx.xx.xx.xx:xx"
``` ```
```yaml tab="YAML" ```yaml tab="YAML"
# http routing section # http routing section
http: http:
routers: routers:
# Define a connection between requests and services # Define a connection between requests and services
to-whoami: to-whoami:
@ -184,26 +188,30 @@ http:
- test-user - test-user
# If the rule matches, forward to the whoami service (declared below) # If the rule matches, forward to the whoami service (declared below)
service: whoami service: whoami
middlewares: middlewares:
# Define an authentication mechanism # Define an authentication mechanism
test-user: test-user:
basicAuth: basicAuth:
users: users:
- test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/ - test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/
services: services:
# Define how to reach an existing service on our infrastructure # Define how to reach an existing service on our infrastructure
whoami: whoami:
loadbalancer: loadBalancer:
servers: servers:
- url: http://private/whoami-service - url: http://private/whoami-service
tcp: tcp:
routers: routers:
to-whoami-tcp: to-whoami-tcp:
service: whoami-tcp service: whoami-tcp
rule: HostSNI(`whoami-tcp.traefik.io`) rule: HostSNI(`whoami-tcp.traefik.io`)
services: services:
whoami-tcp: whoami-tcp:
loadbalancer: loadBalancer:
servers: servers:
- address: xx.xx.xx.xx:xx - address: xx.xx.xx.xx:xx
``` ```

View file

@ -12,42 +12,86 @@ In the process, routers may use pieces of [middleware](../../middlewares/overvie
??? example "Requests /foo are Handled by service-foo -- Using the [File Provider](../../providers/file.md)" ??? example "Requests /foo are Handled by service-foo -- Using the [File Provider](../../providers/file.md)"
```toml ```toml tab="TOML"
[http.routers] [http.routers]
[http.routers.my-router] [http.routers.my-router]
rule = "Path(`/foo`)" rule = "Path(`/foo`)"
service = "service-foo" service = "service-foo"
``` ```
```yaml tab="YAML"
http:
routers:
my-router:
rule: "Path(`/foo`)"
service: service-foo
```
??? example "With a [middleware](../../middlewares/overview.md) -- using the [File Provider](../../providers/file.md)" ??? example "With a [middleware](../../middlewares/overview.md) -- using the [File Provider](../../providers/file.md)"
```toml ```toml tab="TOML"
[http.routers] [http.routers]
[http.routers.my-router] [http.routers.my-router]
rule = "Path(`/foo`)" rule = "Path(`/foo`)"
middlewares = ["authentication"] # declared elsewhere # declared elsewhere
middlewares = ["authentication"]
service = "service-foo" service = "service-foo"
``` ```
```yaml tab="YAML"
http:
routers:
my-router:
rule: "Path(`/foo`)"
# declared elsewhere
middlewares:
- authentication
service: service-foo
```
??? example "Forwarding all (non-tls) requests on port 3306 to a database service" ??? example "Forwarding all (non-tls) requests on port 3306 to a database service"
```toml ```toml tab="TOML"
## Static configuration ##
[entryPoints] [entryPoints]
[entryPoints.mysql-default] [entryPoints.web]
address = ":80" address = ":80"
[entryPoints.mysql-default] [entryPoints.mysql-default]
address = ":3306" address = ":3306"
```
```toml ## Dynamic configuration ##
[tcp] [tcp]
[tcp.routers] [tcp.routers]
[tcp.routers.to-database] [tcp.routers.to-database]
entryPoints = ["mysql-default"] entryPoints = ["mysql-default"]
rule = "HostSNI(`*`)" # Catch every request (only available rule for non-tls routers. See below.) # Catch every request (only available rule for non-tls routers. See below.)
rule = "HostSNI(`*`)"
service = "database" service = "database"
``` ```
```yaml tab="YAML"
## Static configuration ##
entryPoints:
web:
address: ":80"
mysql-default:
address: ":3306"
## Dynamic configuration ##
tcp:
routers:
to-database:
entryPoints:
- "mysql-default"
# Catch every request (only available rule for non-tls routers. See below.)
rule: "HostSNI(`*`)"
service: database
```
## Configuring HTTP Routers ## Configuring HTTP Routers
### EntryPoints ### EntryPoints
@ -57,7 +101,9 @@ If you want to limit the router scope to a set of entry points, set the `entryPo
??? example "Listens to Every EntryPoint" ??? example "Listens to Every EntryPoint"
```toml ```toml tab="TOML"
## Static configuration ##
[entryPoints] [entryPoints]
[entryPoints.web] [entryPoints.web]
# ... # ...
@ -65,9 +111,10 @@ If you want to limit the router scope to a set of entry points, set the `entryPo
# ... # ...
[entryPoints.other] [entryPoints.other]
# ... # ...
```
```toml
## Dynamic configuration ##
[http.routers] [http.routers]
[http.routers.Router-1] [http.routers.Router-1]
# By default, routers listen to every entry points # By default, routers listen to every entry points
@ -75,9 +122,32 @@ If you want to limit the router scope to a set of entry points, set the `entryPo
service = "service-1" service = "service-1"
``` ```
```yaml tab="YAML"
## Static configuration ##
entryPoints:
web:
# ...
web-secure:
# ...
other:
# ...
## Dynamic configuration ##
http:
routers:
Router-1:
# By default, routers listen to every entry points
rule: "Host(`traefik.io`)"
service: "service-1"
```
??? example "Listens to Specific EntryPoints" ??? example "Listens to Specific EntryPoints"
```toml ```toml tab="TOML"
## Static configuration ##
[entryPoints] [entryPoints]
[entryPoints.web] [entryPoints.web]
# ... # ...
@ -85,16 +155,41 @@ If you want to limit the router scope to a set of entry points, set the `entryPo
# ... # ...
[entryPoints.other] [entryPoints.other]
# ... # ...
```
```toml ## Dynamic configuration ##
[http.routers] [http.routers]
[http.routers.Router-1] [http.routers.Router-1]
entryPoints = ["web-secure", "other"] # won't listen to entrypoint web # won't listen to entry point web
entryPoints = ["web-secure", "other"]
rule = "Host(`traefik.io`)" rule = "Host(`traefik.io`)"
service = "service-1" service = "service-1"
``` ```
```yaml tab="YAML"
## Static configuration ##
entryPoints:
web:
# ...
web-secure:
# ...
other:
# ...
## Dynamic configuration ##
http:
routers:
Router-1:
# won't listen to entry point web
entryPoints:
- "web-secure"
- "other"
rule: "Host(`traefik.io`)"
service: "service-1"
```
### Rule ### Rule
Rules are a set of matchers that determine if a particular request matches specific criteria. Rules are a set of matchers that determine if a particular request matches specific criteria.
@ -170,12 +265,23 @@ Traefik will terminate the SSL connections (meaning that it will send decrypted
??? example "Configuring the router to accept HTTPS requests only" ??? example "Configuring the router to accept HTTPS requests only"
```toml ```toml tab="TOML"
[http.routers] [http.routers]
[http.routers.Router-1] [http.routers.Router-1]
rule = "Host(`foo-domain`) && Path(`/foo-path/`)" rule = "Host(`foo-domain`) && Path(`/foo-path/`)"
service = "service-id" service = "service-id"
[http.routers.Router-1.tls] # will terminate the TLS request # will terminate the TLS request
[http.routers.Router-1.tls]
```
```yaml tab="YAML"
http:
routers:
Router-1:
rule: "Host(`foo-domain`) && Path(`/foo-path/`)"
service: service-id
# will terminate the TLS request
tls: {}
``` ```
!!! note "HTTPS & ACME" !!! note "HTTPS & ACME"
@ -192,31 +298,47 @@ Traefik will terminate the SSL connections (meaning that it will send decrypted
??? example "HTTP & HTTPS routes" ??? example "HTTP & HTTPS routes"
```toml ```toml tab="TOML"
[http.routers] [http.routers]
[http.routers.my-https-router] [http.routers.my-https-router]
rule = "Host(`foo-domain`) && Path(`/foo-path/`)" rule = "Host(`foo-domain`) && Path(`/foo-path/`)"
service = "service-id" service = "service-id"
[http.routers.my-https-router.tls] # will terminate the TLS request # will terminate the TLS request
[http.routers.my-https-router.tls]
[http.routers.my-http-router] [http.routers.my-http-router]
rule = "Host(`foo-domain`) && Path(`/foo-path/`)" rule = "Host(`foo-domain`) && Path(`/foo-path/`)"
service = "service-id" service = "service-id"
``` ```
```yaml tab="YAML"
http:
routers:
my-https-router:
rule: "Host(`foo-domain`) && Path(`/foo-path/`)"
service: service-id
# will terminate the TLS request
tls: {}
my-http-router:
rule: "Host(`foo-domain`) && Path(`/foo-path/`)"
service: service-id
```
#### `Options` #### `Options`
The `Options` field enables fine-grained control of the TLS parameters. The `Options` field enables fine-grained control of the TLS parameters.
It refers to a [TLS Options](../../https/tls.md#tls-options) and will be applied only if a `Host` rule is defined. It refers to a [TLS Options](../../https/tls.md#tls-options) and will be applied only if a `Host` rule is defined.
??? example "Configuring the tls options" ??? example "Configuring the TLS options"
```toml ```toml tab="TOML"
[http.routers] [http.routers]
[http.routers.Router-1] [http.routers.Router-1]
rule = "Host(`foo-domain`) && Path(`/foo-path/`)" rule = "Host(`foo-domain`) && Path(`/foo-path/`)"
service = "service-id" service = "service-id"
[http.routers.Router-1.tls] # will terminate the TLS request # will terminate the TLS request
[http.routers.Router-1.tls]
options = "foo" options = "foo"
[tls.options] [tls.options]
@ -228,6 +350,25 @@ It refers to a [TLS Options](../../https/tls.md#tls-options) and will be applied
] ]
``` ```
```yaml tab="YAML"
http:
routers:
Router-1:
rule: "Host(`foo-domain`) && Path(`/foo-path/`)"
service: service-id
# will terminate the TLS request
tls:
options: foo
tls:
options:
foo:
minVersion: VersionTLS12
cipherSuites:
- TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256
- TLS_RSA_WITH_AES_256_GCM_SHA384
```
## Configuring TCP Routers ## Configuring TCP Routers
### General ### General
@ -242,7 +383,9 @@ If you want to limit the router scope to a set of entry points, set the entry po
??? example "Listens to Every Entry Point" ??? example "Listens to Every Entry Point"
```toml ```toml tab="TOML"
## Static configuration ##
[entryPoints] [entryPoints]
[entryPoints.web] [entryPoints.web]
# ... # ...
@ -250,20 +393,46 @@ If you want to limit the router scope to a set of entry points, set the entry po
# ... # ...
[entryPoints.other] [entryPoints.other]
# ... # ...
```
```toml ## Dynamic configuration ##
[tcp.routers] [tcp.routers]
[tcp.routers.Router-1] [tcp.routers.Router-1]
# By default, routers listen to every entrypoints # By default, routers listen to every entrypoints
rule = "HostSNI(`traefik.io`)" rule = "HostSNI(`traefik.io`)"
service = "service-1" service = "service-1"
[tcp.routers.Router-1.tls] # will route TLS requests (and ignore non tls requests) # will route TLS requests (and ignore non tls requests)
[tcp.routers.Router-1.tls]
```
```yaml tab="YAML"
## Static configuration ##
entryPoints:
web:
# ...
web-secure:
# ...
other:
# ...
## Dynamic configuration ##
tcp:
routers:
Router-1:
# By default, routers listen to every entrypoints
rule: "HostSNI(`traefik.io`)"
service: "service-1"
# will route TLS requests (and ignore non tls requests)
tls: {}
``` ```
??? example "Listens to Specific Entry Points" ??? example "Listens to Specific Entry Points"
```toml ```toml tab="TOML"
## Static configuration ##
[entryPoints] [entryPoints]
[entryPoints.web] [entryPoints.web]
# ... # ...
@ -271,15 +440,43 @@ If you want to limit the router scope to a set of entry points, set the entry po
# ... # ...
[entryPoints.other] [entryPoints.other]
# ... # ...
```
```toml ## Dynamic configuration ##
[tcp.routers] [tcp.routers]
[tcp.routers.Router-1] [tcp.routers.Router-1]
entryPoints = ["web-secure", "other"] # won't listen to entrypoint web # won't listen to entry point web
entryPoints = ["web-secure", "other"]
rule = "HostSNI(`traefik.io`)" rule = "HostSNI(`traefik.io`)"
service = "service-1" service = "service-1"
[tcp.routers.Router-1.tls] # will route TLS requests (and ignore non tls requests) # will route TLS requests (and ignore non tls requests)
[tcp.routers.Router-1.tls]
```
```yaml tab="YAML"
## Static configuration ##
entryPoints:
web:
# ...
web-secure:
# ...
other:
# ...
## Dynamic configuration ##
tcp:
routers:
Router-1:
# won't listen to entry point web
entryPoints:
- "web-secure"
- "other"
rule: "HostSNI(`traefik.io`)"
service: "service-1"
# will route TLS requests (and ignore non tls requests)
tls: {}
``` ```
### Rule ### Rule
@ -312,17 +509,28 @@ Services are the target for the router.
??? example "Configuring TLS Termination" ??? example "Configuring TLS Termination"
```toml ```toml tab="TOML"
[tcp.routers] [tcp.routers]
[tcp.routers.Router-1] [tcp.routers.Router-1]
rule = "HostSNI(`foo-domain`)" rule = "HostSNI(`foo-domain`)"
service = "service-id" service = "service-id"
[tcp.routers.Router-1.tls] # will terminate the TLS request by default # will terminate the TLS request by default
[tcp.routers.Router-1.tls]
```
```yaml tab="YAML"
tcp:
routers:
Router-1:
rule: "HostSNI(`foo-domain`)"
service: service-id
# will terminate the TLS request by default
tld: {}
``` ```
??? example "Configuring passthrough" ??? example "Configuring passthrough"
```toml ```toml tab="TOML"
[tcp.routers] [tcp.routers]
[tcp.routers.Router-1] [tcp.routers.Router-1]
rule = "HostSNI(`foo-domain`)" rule = "HostSNI(`foo-domain`)"
@ -331,6 +539,16 @@ Services are the target for the router.
passthrough = true passthrough = true
``` ```
```yaml tab="YAML"
tcp:
routers:
Router-1:
rule: "HostSNI(`foo-domain`)"
service: service-id
tls:
passthrough: true
```
!!! note "TLS & ACME" !!! note "TLS & ACME"
In the current version, with [ACME](../../https/acme.md) enabled, automatic certificate generation will apply to every router declaring a TLS section. In the current version, with [ACME](../../https/acme.md) enabled, automatic certificate generation will apply to every router declaring a TLS section.
@ -342,12 +560,13 @@ It refers to a [TLS Options](../../https/tls.md#tls-options) and will be applied
??? example "Configuring the tls options" ??? example "Configuring the tls options"
```toml ```toml tab="TOML"
[tcp.routers] [tcp.routers]
[tcp.routers.Router-1] [tcp.routers.Router-1]
rule = "HostSNI(`foo-domain`)" rule = "HostSNI(`foo-domain`)"
service = "service-id" service = "service-id"
[tcp.routers.Router-1.tls] # will terminate the TLS request # will terminate the TLS request
[tcp.routers.Router-1.tls]
options = "foo" options = "foo"
[tls.options] [tls.options]
@ -358,3 +577,22 @@ It refers to a [TLS Options](../../https/tls.md#tls-options) and will be applied
"TLS_RSA_WITH_AES_256_GCM_SHA384" "TLS_RSA_WITH_AES_256_GCM_SHA384"
] ]
``` ```
```yaml tab="YAML"
tcp:
routers:
Router-1:
rule: "HostSNI(`foo-domain`)"
service: service-id
# will terminate the TLS request
tls:
options: foo
tls:
options:
foo:
minVersion: VersionTLS12
cipherSuites:
- "TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256"
- "TLS_RSA_WITH_AES_256_GCM_SHA384"
```

View file

@ -11,27 +11,47 @@ The `Services` are responsible for configuring how to reach the actual services
??? example "Declaring an HTTP Service with Two Servers -- Using the [File Provider](../../providers/file.md)" ??? example "Declaring an HTTP Service with Two Servers -- Using the [File Provider](../../providers/file.md)"
```toml ```toml tab="TOML"
[http.services] [http.services]
[http.services.my-service.LoadBalancer] [http.services.my-service.loadBalancer]
[[http.services.my-service.LoadBalancer.servers]] [[http.services.my-service.loadBalancer.servers]]
url = "http://private-ip-server-1/" url = "http://private-ip-server-1/"
[[http.services.my-service.LoadBalancer.servers]] [[http.services.my-service.loadBalancer.servers]]
url = "http://private-ip-server-2/" url = "http://private-ip-server-2/"
``` ```
```yaml tab="YAML"
http:
services:
my-service:
loadBalancer:
servers:
- url: "http://private-ip-server-1/"
- url: "http://private-ip-server-2/"
```
??? example "Declaring a TCP Service with Two Servers -- Using the [File Provider](../../providers/file.md)" ??? example "Declaring a TCP Service with Two Servers -- Using the [File Provider](../../providers/file.md)"
```toml ```toml tab="TOML"
[tcp.services] [tcp.services]
[tcp.services.my-service.LoadBalancer] [tcp.services.my-service.loadBalancer]
[[tcp.services.my-service.LoadBalancer.servers]] [[tcp.services.my-service.loadBalancer.servers]]
address = "xx.xx.xx.xx:xx" address = "xx.xx.xx.xx:xx"
[[tcp.services.my-service.LoadBalancer.servers]] [[tcp.services.my-service.loadBalancer.servers]]
address = "xx.xx.xx.xx:xx" address = "xx.xx.xx.xx:xx"
``` ```
```yaml tab="YAML"
tcp:
services:
my-service:
loadBalancer:
servers:
- address: "xx.xx.xx.xx:xx"
- address: "xx.xx.xx.xx:xx"
```
## Configuring HTTP Services ## Configuring HTTP Services
### General ### General
@ -46,16 +66,26 @@ The load balancers are able to load balance the requests between multiple instan
??? example "Declaring a Service with Two Servers (with Load Balancing) -- Using the [File Provider](../../providers/file.md)" ??? example "Declaring a Service with Two Servers (with Load Balancing) -- Using the [File Provider](../../providers/file.md)"
```toml ```toml tab="TOML"
[http.services] [http.services]
[http.services.my-service.LoadBalancer] [http.services.my-service.loadBalancer]
[[http.services.my-service.LoadBalancer.servers]] [[http.services.my-service.loadBalancer.servers]]
url = "http://private-ip-server-1/" url = "http://private-ip-server-1/"
[[http.services.my-service.LoadBalancer.servers]] [[http.services.my-service.loadBalancer.servers]]
url = "http://private-ip-server-2/" url = "http://private-ip-server-2/"
``` ```
```yaml tab="YAML"
http:
services:
my-service:
loadBalancer:
servers:
- url: "http://private-ip-server-1/"
- url: "http://private-ip-server-2/"
```
#### Servers #### Servers
Servers declare a single instance of your program. Servers declare a single instance of your program.
@ -68,26 +98,45 @@ The `url` option point to a specific instance.
??? example "A Service with One Server -- Using the [File Provider](../../providers/file.md)" ??? example "A Service with One Server -- Using the [File Provider](../../providers/file.md)"
```toml ```toml tab="TOML"
[http.services] [http.services]
[http.services.my-service.LoadBalancer] [http.services.my-service.loadBalancer]
[[http.services.my-service.LoadBalancer.servers]] [[http.services.my-service.loadBalancer.servers]]
url = "http://private-ip-server-1/" url = "http://private-ip-server-1/"
``` ```
```yaml tab="YAML"
http:
services:
my-service:
loadBalancer:
servers:
url: "http://private-ip-server-1/"
```
#### Load-balancing #### Load-balancing
For now, only round robin load balancing is supported: For now, only round robin load balancing is supported:
??? example "Load Balancing -- Using the [File Provider](../../providers/file.md)" ??? example "Load Balancing -- Using the [File Provider](../../providers/file.md)"
```toml ```toml tab="TOML"
[http.services] [http.services]
[http.services.my-service.LoadBalancer] [http.services.my-service.loadBalancer]
[[http.services.my-service.LoadBalancer.servers]] [[http.services.my-service.loadBalancer.servers]]
url = "http://private-ip-server-1/"
[[http.services.my-service.LoadBalancer.servers]]
url = "http://private-ip-server-1/" url = "http://private-ip-server-1/"
[[http.services.my-service.loadBalancer.servers]]
url = "http://private-ip-server-2/"
```
```yaml tab="YAML"
http:
services:
my-service:
loadBalancer:
servers:
- url: "http://private-ip-server-1/"
- url: "http://private-ip-server-2/"
``` ```
#### Sticky sessions #### Sticky sessions
@ -109,25 +158,42 @@ On subsequent requests, the client is forwarded to the same server.
??? example "Adding Stickiness" ??? example "Adding Stickiness"
```toml ```toml tab="TOML"
[http.services] [http.services]
[http.services.my-service] [http.services.my-service]
[http.services.my-service.LoadBalancer.stickiness] [http.services.my-service.loadBalancer.stickiness]
secureCookie = true ```
httpOnlyCookie = true
```yaml tab="YAML"
http:
services:
my-service:
loadBalancer:
stickiness: {}
``` ```
??? example "Adding Stickiness with a Custom Cookie Name" ??? example "Adding Stickiness with a Custom Cookie Name"
```toml ```toml tab="TOML"
[http.services] [http.services]
[http.services.my-service] [http.services.my-service]
[http.services.my-service.LoadBalancer.stickiness] [http.services.my-service.loadBalancer.stickiness]
cookieName = "my_stickiness_cookie_name" cookieName = "my_stickiness_cookie_name"
secureCookie = true secureCookie = true
httpOnlyCookie = true httpOnlyCookie = true
``` ```
```yaml tab="YAML"
http:
services:
my-service:
loadBalancer:
stickiness:
cookieName: my_stickiness_cookie_name
secureCookie: true
httpOnlyCookie: true
```
#### Health Check #### Health Check
Configure health check to remove unhealthy servers from the load balancing rotation. Configure health check to remove unhealthy servers from the load balancing rotation.
@ -135,7 +201,7 @@ Traefik will consider your servers healthy as long as they return status codes b
Below are the available options for the health check mechanism: Below are the available options for the health check mechanism:
- `path` is appended to the server URL to set the healcheck endpoint. - `path` is appended to the server URL to set the health check endpoint.
- `scheme`, if defined, will replace the server URL `scheme` for the health check endpoint - `scheme`, if defined, will replace the server URL `scheme` for the health check endpoint
- `hostname`, if defined, will replace the server URL `hostname` for the health check endpoint. - `hostname`, if defined, will replace the server URL `hostname` for the health check endpoint.
- `port`, if defined, will replace the server URL `port` for the health check endpoint. - `port`, if defined, will replace the server URL `port` for the health check endpoint.
@ -153,50 +219,93 @@ Below are the available options for the health check mechanism:
Traefik keeps monitoring the health of unhealthy servers. Traefik keeps monitoring the health of unhealthy servers.
If a server has recovered (returning `2xx` -> `3xx` responses again), it will be added back to the load balacer rotation pool. If a server has recovered (returning `2xx` -> `3xx` responses again), it will be added back to the load balacer rotation pool.
??? example "Custom Interval & Timeout -- Using the File Provider" ??? example "Custom Interval & Timeout -- Using the [File Provider](../../providers/file.md)"
```toml ```toml tab="TOML"
[http.services] [http.services]
[http.servicess.Service-1] [http.servicess.Service-1]
[http.services.Service-1.healthcheck] [http.services.Service-1.loadBalancer.healthCheck]
path = "/health" path = "/health"
interval = "10s" interval = "10s"
timeout = "3s" timeout = "3s"
``` ```
??? example "Custom Port -- Using the File Provider" ```yaml tab="YAML"
http:
servicess:
Service-1:
loadBalancer:
healthCheck:
path: /health
interval: "10s"
timeout: "3s"
```
```toml ??? example "Custom Port -- Using the [File Provider](../../providers/file.md)"
```toml tab="TOML"
[http.services] [http.services]
[http.services.Service-1] [http.services.Service-1]
[http.services.Service-1.healthcheck] [http.services.Service-1.loadBalancer.healthCheck]
path = "/health" path = "/health"
port = 8080 port = 8080
``` ```
??? example "Custom Scheme -- Using the File Provider" ```yaml tab="YAML"
http:
services:
Service-1:
loadBalancer:
healthCheck:
path: /health
port: 8080
```
```toml ??? example "Custom Scheme -- Using the [File Provider](../../providers/file.md)"
```toml tab="TOML"
[http.services] [http.services]
[http.services.Service-1] [http.services.Service-1]
[http.services.Service-1.healthcheck] [http.services.Service-1.loadBalancer.healthCheck]
path = "/health" path = "/health"
scheme = "http" scheme = "http"
``` ```
??? example "Additional HTTP Headers -- Using the File Provider" ```yaml tab="YAML"
http:
services:
Service-1:
loadBalancer:
healthCheck:
path: /health
scheme: http
```
```toml ??? example "Additional HTTP Headers -- Using the [File Provider](../../providers/file.md)"
```toml tab="TOML"
[http.services] [http.services]
[http.services.Service-1] [http.services.Service-1]
[http.servicess.Service-1.healthcheck] [http.services.Service-1.loadBalancer.healthCheck]
path = "/health" path = "/health"
[Service.Service-1.healthcheck.headers] [http.services.Service-1.loadBalancer.healthCheck.headers]
My-Custom-Header = "foo" My-Custom-Header = "foo"
My-Header = "bar" My-Header = "bar"
``` ```
```yaml tab="YAML"
http:
services:
Service-1:
loadBalancer:
healthCheck:
path: /health
headers:
My-Custom-Header: foo
My-Header: bar
```
## Configuring TCP Services ## Configuring TCP Services
### General ### General
@ -211,15 +320,25 @@ The load balancers are able to load balance the requests between multiple instan
??? example "Declaring a Service with Two Servers -- Using the [File Provider](../../providers/file.md)" ??? example "Declaring a Service with Two Servers -- Using the [File Provider](../../providers/file.md)"
```toml ```toml tab="TOML"
[tcp.services] [tcp.services]
[tcp.services.my-service.LoadBalancer] [tcp.services.my-service.loadBalancer]
[[tcp.services.my-service.LoadBalancer.servers]] [[tcp.services.my-service.loadBalancer.servers]]
address = "xx.xx.xx.xx:xx" address = "xx.xx.xx.xx:xx"
[[tcp.services.my-service.LoadBalancer.servers]] [[tcp.services.my-service.loadBalancer.servers]]
address = "xx.xx.xx.xx:xx" address = "xx.xx.xx.xx:xx"
``` ```
```yaml tab="YAML"
tcp:
services:
my-service:
loadBalancer:
servers:
- address: "xx.xx.xx.xx:xx"
- address: "xx.xx.xx.xx:xx"
```
#### Servers #### Servers
Servers declare a single instance of your program. Servers declare a single instance of your program.
@ -227,9 +346,18 @@ The `address` option (IP:Port) point to a specific instance.
??? example "A Service with One Server -- Using the [File Provider](../../providers/file.md)" ??? example "A Service with One Server -- Using the [File Provider](../../providers/file.md)"
```toml ```toml tab="TOML"
[tcp.services] [tcp.services]
[tcp.services.my-service.LoadBalancer] [tcp.services.my-service.loadBalancer]
[[tcp.services.my-service.LoadBalancer.servers]] [[tcp.services.my-service.loadBalancer.servers]]
address = "xx.xx.xx.xx:xx" address = "xx.xx.xx.xx:xx"
``` ```
```yaml tab="YAML"
tcp:
services:
my-service:
loadBalancer:
servers:
address: "xx.xx.xx.xx:xx"
```

View file

@ -17,10 +17,10 @@ Traefik tries to detect the configured mode and route traffic to the right IP ad
Traefik also attempts to determine the right port (which is a [non-trivial matter in Marathon](https://mesosphere.github.io/marathon/docs/ports.html)). Traefik also attempts to determine the right port (which is a [non-trivial matter in Marathon](https://mesosphere.github.io/marathon/docs/ports.html)).
Following is the order by which Traefik tries to identify the port (the first one that yields a positive result will be used): Following is the order by which Traefik tries to identify the port (the first one that yields a positive result will be used):
1. A arbitrary port specified through the `traefik.HTTP.Services.ServiceName.LoadBalancer.server.Port=8080` 1. A arbitrary port specified through the `traefik.http.services.serviceName.loadbalancer.server.port=8080`
1. The task port (possibly indexed through the `traefik.HTTP.Services.ServiceName.LoadBalancer.server.Port=index:0` label, otherwise the first one). 1. The task port (possibly indexed through the `traefik.http.services.serviceName.loadbalancer.server.port=index:0` label, otherwise the first one).
1. The port from the application's `portDefinitions` field (possibly indexed through the `traefik.HTTP.Services.ServiceName.LoadBalancer.server.Port=index:0` label, otherwise the first one). 1. The port from the application's `portDefinitions` field (possibly indexed through the `traefik.http.services.serviceName.loadbalancer.server.port=index:0` label, otherwise the first one).
1. The port from the application's `ipAddressPerTask` field (possibly indexed through the `traefik.HTTP.Services.ServiceName.LoadBalancer.server.Port=index:0` label, otherwise the first one). 1. The port from the application's `ipAddressPerTask` field (possibly indexed through the `traefik.http.services.serviceName.loadbalancer.server.port=index:0` label, otherwise the first one).
## Achieving high availability ## Achieving high availability
@ -47,7 +47,7 @@ Beginning with version 1.4, Traefik respects readiness check results if the Trae
!!! note !!! note
Due to the way readiness check results are currently exposed by the Marathon API, ready tasks may be taken into rotation with a small delay. Due to the way readiness check results are currently exposed by the Marathon API, ready tasks may be taken into rotation with a small delay.
It is on the order of one readiness check timeout interval (as configured on the application specifiation) and guarantees that non-ready tasks do not receive traffic prematurely. It is on the order of one readiness check timeout interval (as configured on the application specification) and guarantees that non-ready tasks do not receive traffic prematurely.
If readiness checks are not possible, a current mitigation strategy is to enable [retries](../middlewares/retry.md) and make sure that a sufficient number of healthy application tasks exist so that one retry will likely hit one of those. If readiness checks are not possible, a current mitigation strategy is to enable [retries](../middlewares/retry.md) and make sure that a sufficient number of healthy application tasks exist so that one retry will likely hit one of those.
Apart from its probabilistic nature, the workaround comes at the price of increased latency. Apart from its probabilistic nature, the workaround comes at the price of increased latency.
@ -80,7 +80,7 @@ Failure reasons vary broadly and could stretch from unacceptable slowness, a tas
There are two mitigaton efforts: There are two mitigaton efforts:
1. Configure [Marathon health checks](https://mesosphere.github.io/marathon/docs/health-checks.html) on each application. 1. Configure [Marathon health checks](https://mesosphere.github.io/marathon/docs/health-checks.html) on each application.
2. Configure Traefik health checks (possibly via the `traefik.HTTP.Services.YourServiceName.LoadBalancer.HealthCheck.*` labels) and make sure they probe with proper frequency. 2. Configure Traefik health checks (possibly via the `traefik.http.services.yourServiceName.loadbalancer.healthcheck.*` labels) and make sure they probe with proper frequency.
The Marathon health check makes sure that applications once deemed dysfunctional are being rescheduled to different slaves. The Marathon health check makes sure that applications once deemed dysfunctional are being rescheduled to different slaves.
However, they might take a while to get triggered and the follow-up processes to complete. However, they might take a while to get triggered and the follow-up processes to complete.

View file

@ -42,9 +42,11 @@ level = "DEBUG"
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.services] [http.services]
[http.services.test.loadbalancer] [http.services.test.loadBalancer]
[[http.services.test.loadbalancer.servers]] [[http.services.test.loadBalancer.servers]]
url = "http://127.0.0.1:9010" url = "http://127.0.0.1:9010"
[http.routers] [http.routers]

View file

@ -42,9 +42,11 @@ level = "DEBUG"
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.services] [http.services]
[http.services.test.loadbalancer] [http.services.test.loadBalancer]
[[http.services.test.loadbalancer.servers]] [[http.services.test.loadBalancer.servers]]
url = "http://127.0.0.1:9010" url = "http://127.0.0.1:9010"
[http.routers] [http.routers]

View file

@ -16,7 +16,7 @@ level = "DEBUG"
address = ":9000" address = ":9000"
# FIXME # FIXME
# [entryPoints.traefik.tls] # [entryPoints.traefik.tls]
# [entryPoints.traefik.tls.DefaultCertificate] # [entryPoints.traefik.tls.defaultCertificate]
# certFile = "fixtures/acme/ssl/wildcard.crt" # certFile = "fixtures/acme/ssl/wildcard.crt"
# keyFile = "fixtures/acme/ssl/wildcard.key" # keyFile = "fixtures/acme/ssl/wildcard.key"

View file

@ -1,6 +1,6 @@
[http.services] [http.services]
[http.services.test.loadbalancer] [http.services.test.loadBalancer]
[[http.services.test.loadbalancer.servers]] [[http.services.test.loadBalancer.servers]]
url = "http://127.0.0.1:9010" url = "http://127.0.0.1:9010"
[http.routers] [http.routers]

View file

@ -12,9 +12,11 @@ level = "DEBUG"
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
Rule = "Host(`test.local`)" rule = "Host(`test.local`)"
service = "service1" service = "service1"
middlewares = ["error"] middlewares = ["error"]
@ -25,11 +27,11 @@ level = "DEBUG"
query = "/50x.html" query = "/50x.html"
[http.services] [http.services]
[http.services.service1.loadbalancer] [http.services.service1.loadBalancer]
passHostHeader = true passHostHeader = true
[[http.services.service1.loadbalancer.servers]] [[http.services.service1.loadBalancer.servers]]
url = "http://{{.Server1}}:8989474" url = "http://{{.Server1}}:8989474"
[http.services.error.loadbalancer] [http.services.error.loadBalancer]
[[http.services.error.loadbalancer.servers]] [[http.services.error.loadBalancer.servers]]
url = "http://{{.Server2}}:80" url = "http://{{.Server2}}:80"

View file

@ -12,9 +12,11 @@ level = "DEBUG"
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
Rule = "Host(`test.local`)" rule = "Host(`test.local`)"
service = "service1" service = "service1"
middlewares = ["error"] middlewares = ["error"]
@ -25,11 +27,11 @@ level = "DEBUG"
query = "/50x.html" query = "/50x.html"
[http.services] [http.services]
[http.services.service1.loadbalancer] [http.services.service1.loadBalancer]
passHostHeader = true passHostHeader = true
[[http.services.service1.loadbalancer.servers]] [[http.services.service1.loadBalancer.servers]]
url = "http://{{.Server1}}:80" url = "http://{{.Server1}}:80"
[http.services.error.loadbalancer] [http.services.error.loadBalancer]
[[http.services.error.loadbalancer.servers]] [[http.services.error.loadBalancer.servers]]
url = "http://{{.Server2}}:80" url = "http://{{.Server2}}:80"

View file

@ -9,6 +9,5 @@ level = "DEBUG"
[entryPoints.web] [entryPoints.web]
address = ":8000" address = ":8000"
[providers] [providers]
[providers.file] [providers.file]

View file

@ -4,6 +4,6 @@
service = "service1" service = "service1"
[http.services] [http.services]
[http.services.service1.loadbalancer] [http.services.service1.loadBalancer]
[[http.services.service1.loadbalancer.servers]] [[http.services.service1.loadBalancer.servers]]
url = "http://172.17.0.2:80" url = "http://172.17.0.2:80"

View file

@ -4,6 +4,6 @@
service = "service2" service = "service2"
[http.services] [http.services]
[http.services.service2.loadbalancer] [http.services.service2.loadBalancer]
[[http.services.service2.loadbalancer.servers]] [[http.services.service2.loadBalancer.servers]]
url = "http://172.17.0.123:80" url = "http://172.17.0.123:80"

View file

@ -12,6 +12,8 @@ level = "DEBUG"
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
rule = "Host(`test.localhost`)" rule = "Host(`test.localhost`)"
@ -22,6 +24,6 @@ level = "DEBUG"
service = "service1" service = "service1"
[http.services] [http.services]
[http.services.service1.loadbalancer] [http.services.service1.loadBalancer]
[[http.services.service1.loadbalancer.servers]] [[http.services.service1.loadBalancer.servers]]
URL = "{{.Server}}" url = "{{.Server}}"

View file

@ -12,6 +12,8 @@ level = "DEBUG"
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
rule = "Host(`test.localhost`)" rule = "Host(`test.localhost`)"
@ -23,19 +25,19 @@ level = "DEBUG"
service = "service1" service = "service1"
[http.middlewares] [http.middlewares]
[http.middlewares.circuitbreaker.circuitbreaker] [http.middlewares.circuitbreaker.circuitBreaker]
expression = "NetworkErrorRatio() > 0.5" expression = "NetworkErrorRatio() > 0.5"
[http.services] [http.services]
[http.services.service1.loadbalancer] [http.services.service1.loadBalancer]
[[http.services.service1.loadbalancer.servers]] [[http.services.service1.loadBalancer.servers]]
url = "http://172.17.0.2:80" url = "http://172.17.0.2:80"
[[http.services.service1.loadbalancer.servers]] [[http.services.service1.loadBalancer.servers]]
url = "http://172.17.0.3:80" url = "http://172.17.0.3:80"
[http.services.service2] [http.services.service2]
[http.services.service2.loadbalancer] [http.services.service2.loadBalancer]
[[http.services.service2.loadbalancer.servers]] [[http.services.service2.loadBalancer.servers]]
url = "http://172.17.0.4:80" url = "http://172.17.0.4:80"
[[http.services.service2.loadbalancer.servers]] [[http.services.service2.loadBalancer.servers]]
url = "http://172.17.0.5:80" url = "http://172.17.0.5:80"

View file

@ -17,6 +17,8 @@ rootCAs = [ """{{ .CertContent }}""" ]
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
rule = "Host(`127.0.0.1`)" rule = "Host(`127.0.0.1`)"
@ -24,11 +26,11 @@ rootCAs = [ """{{ .CertContent }}""" ]
[http.routers.router1.tls] [http.routers.router1.tls]
[http.services] [http.services]
[http.services.service1.loadbalancer] [http.services.service1.loadBalancer]
[[http.services.service1.loadbalancer.servers]] [[http.services.service1.loadBalancer.servers]]
url = "https://127.0.0.1:{{ .GRPCServerPort }}" url = "https://127.0.0.1:{{ .GRPCServerPort }}"
[tls.stores] [tls.stores]
[tls.stores.default.DefaultCertificate] [tls.stores.default.defaultCertificate]
certFile = """{{ .CertContent }}""" certFile = """{{ .CertContent }}"""
keyFile = """{{ .KeyContent }}""" keyFile = """{{ .KeyContent }}"""

View file

@ -14,12 +14,14 @@ level = "DEBUG"
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
rule = "Host(`127.0.0.1`)" rule = "Host(`127.0.0.1`)"
service = "service1" service = "service1"
[http.services] [http.services]
[http.services.service1.loadbalancer] [http.services.service1.loadBalancer]
[[http.services.service1.loadbalancer.servers]] [[http.services.service1.loadBalancer.servers]]
url = "h2c://127.0.0.1:{{ .GRPCServerPort }}" url = "h2c://127.0.0.1:{{ .GRPCServerPort }}"

View file

@ -9,12 +9,13 @@ level = "DEBUG"
[entryPoints.web-secure] [entryPoints.web-secure]
address = ":4443" address = ":4443"
[api] [api]
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
rule = "Host(`127.0.0.1`)" rule = "Host(`127.0.0.1`)"
@ -22,11 +23,11 @@ level = "DEBUG"
[http.routers.router1.tls] [http.routers.router1.tls]
[http.services] [http.services]
[http.services.service1.loadbalancer] [http.services.service1.loadBalancer]
[[http.services.service1.loadbalancer.servers]] [[http.services.service1.loadBalancer.servers]]
url = "h2c://127.0.0.1:{{ .GRPCServerPort }}" url = "h2c://127.0.0.1:{{ .GRPCServerPort }}"
[tls.stores] [tls.stores]
[tls.stores.default.DefaultCertificate] [tls.stores.default.defaultCertificate]
certFile = """{{ .CertContent }}""" certFile = """{{ .CertContent }}"""
keyFile = """{{ .KeyContent }}""" keyFile = """{{ .KeyContent }}"""

View file

@ -17,6 +17,8 @@ insecureSkipVerify = true
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
rule = "Host(`127.0.0.1`)" rule = "Host(`127.0.0.1`)"
@ -24,11 +26,11 @@ insecureSkipVerify = true
[http.routers.router1.tls] [http.routers.router1.tls]
[http.services] [http.services]
[http.services.service1.loadbalancer] [http.services.service1.loadBalancer]
[[http.services.service1.loadbalancer.servers]] [[http.services.service1.loadBalancer.servers]]
url = "https://127.0.0.1:{{ .GRPCServerPort }}" url = "https://127.0.0.1:{{ .GRPCServerPort }}"
[tls.stores] [tls.stores]
[tls.stores.default.DefaultCertificate] [tls.stores.default.defaultCertificate]
certFile = """{{ .CertContent }}""" certFile = """{{ .CertContent }}"""
keyFile = """{{ .KeyContent }}""" keyFile = """{{ .KeyContent }}"""

View file

@ -17,6 +17,8 @@ rootCAs = [ """{{ .CertContent }}""" ]
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
rule = "Host(`127.0.0.1`)" rule = "Host(`127.0.0.1`)"
@ -26,16 +28,16 @@ rootCAs = [ """{{ .CertContent }}""" ]
[http.middlewares] [http.middlewares]
[http.middlewares.retryer.retry] [http.middlewares.retryer.retry]
Attempts = 2 attempts = 2
[http.services] [http.services]
[http.services.service1.loadbalancer] [http.services.service1.loadBalancer]
[http.services.service1.loadbalancer.responseForwarding] [http.services.service1.loadBalancer.responseForwarding]
flushInterval = "1ms" flushInterval = "1ms"
[[http.services.service1.loadbalancer.servers]] [[http.services.service1.loadBalancer.servers]]
url = "https://127.0.0.1:{{ .GRPCServerPort }}" url = "https://127.0.0.1:{{ .GRPCServerPort }}"
[tls.stores] [tls.stores]
[tls.stores.default.DefaultCertificate] [tls.stores.default.defaultCertificate]
certFile = """{{ .CertContent }}""" certFile = """{{ .CertContent }}"""
keyFile = """{{ .KeyContent }}""" keyFile = """{{ .KeyContent }}"""

View file

@ -12,12 +12,14 @@ level = "DEBUG"
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
rule = "Host(`test.localhost`)" rule = "Host(`test.localhost`)"
service = "service1" service = "service1"
[http.services] [http.services]
[http.services.service1.loadbalancer] [http.services.service1.loadBalancer]
[[http.services.service1.loadbalancer.servers]] [[http.services.service1.loadBalancer.servers]]
url = "http://172.17.0.2:80" url = "http://172.17.0.2:80"

View file

@ -12,19 +12,21 @@ level = "DEBUG"
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
rule = "Host(`test.localhost`)" rule = "Host(`test.localhost`)"
service = "service1" service = "service1"
[http.middlewares] [http.middlewares]
[http.middlewares.cors.Headers] [http.middlewares.cors.headers]
AccessControlAllowMethods= ["GET", "OPTIONS", "PUT"] accessControlAllowMethods= ["GET", "OPTIONS", "PUT"]
AccessControlAllowOrigin = "origin-list-or-null" accessControlAllowOrigin = "origin-list-or-null"
AccessControlMaxAge = 100 accessControlMaxAge = 100
AddVaryHeader = true addVaryHeader = true
[http.services] [http.services]
[http.services.service1.loadbalancer] [http.services.service1.loadBalancer]
[[http.services.service1.loadbalancer.servers]] [[http.services.service1.loadBalancer.servers]]
url = "http://172.17.0.2:80" url = "http://172.17.0.2:80"

View file

@ -16,18 +16,20 @@ level = "DEBUG"
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
service = "service1" service = "service1"
Rule = "Host(`test.localhost`)" rule = "Host(`test.localhost`)"
[http.services] [http.services]
[http.services.service1.loadbalancer] [http.services.service1.loadBalancer]
[http.services.service1.loadbalancer.healthcheck] [http.services.service1.loadBalancer.healthcheck]
path = "/health" path = "/health"
interval = "1s" interval = "1s"
timeout = "0.9s" timeout = "0.9s"
[[http.services.service1.loadbalancer.servers]] [[http.services.service1.loadBalancer.servers]]
url = "http://{{.Server1}}:80" url = "http://{{.Server1}}:80"
[[http.services.service1.loadbalancer.servers]] [[http.services.service1.loadBalancer.servers]]
url = "http://{{.Server2}}:80" url = "http://{{.Server2}}:80"

View file

@ -14,17 +14,19 @@ level = "DEBUG"
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
service = "service1" service = "service1"
Rule = "Host(`test.localhost`)" rule = "Host(`test.localhost`)"
[http.services] [http.services]
[http.services.service1.loadbalancer] [http.services.service1.loadBalancer]
[http.services.service1.loadbalancer.healthcheck] [http.services.service1.loadBalancer.healthcheck]
path = "/health" path = "/health"
port = 80 port = 80
interval = "1s" interval = "1s"
timeout = "0.9s" timeout = "0.9s"
[[http.services.service1.loadbalancer.servers]] [[http.services.service1.loadBalancer.servers]]
url = "http://{{.Server1}}:81" url = "http://{{.Server1}}:81"

View file

@ -14,18 +14,20 @@ level = "DEBUG"
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
service = "service1" service = "service1"
Rule = "Host(`test.localhost`)" rule = "Host(`test.localhost`)"
[http.services] [http.services]
[http.services.service1.loadbalancer] [http.services.service1.loadBalancer]
[http.services.service1.loadbalancer.healthcheck] [http.services.service1.loadBalancer.healthcheck]
path = "/health" path = "/health"
interval = "1s" interval = "1s"
timeout = "0.9s" timeout = "0.9s"
[[http.services.service1.loadbalancer.servers]] [[http.services.service1.loadBalancer.servers]]
url = "http://{{.Server1}}:80" url = "http://{{.Server1}}:80"
[[http.services.service1.loadbalancer.servers]] [[http.services.service1.loadBalancer.servers]]
url = "http://{{.Server2}}:80" url = "http://{{.Server2}}:80"

View file

@ -14,27 +14,29 @@ level = "DEBUG"
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
Service = "service1" service = "service1"
Rule = "Host(`snitest.com`)" rule = "Host(`snitest.com`)"
[http.routers.router1.tls] [http.routers.router1.tls]
[http.routers.router2] [http.routers.router2]
Service = "service2" service = "service2"
Rule = "Host(`snitest.org`)" rule = "Host(`snitest.org`)"
[http.routers.router2.tls] [http.routers.router2.tls]
[http.services] [http.services]
[http.services.service1] [http.services.service1]
[http.services.service1.LoadBalancer] [http.services.service1.loadBalancer]
[[http.services.service1.LoadBalancer.Servers]] [[http.services.service1.loadBalancer.servers]]
URL = "http://127.0.0.1:9010" url = "http://127.0.0.1:9010"
[http.services.service2] [http.services.service2]
[http.services.service2.LoadBalancer] [http.services.service2.loadBalancer]
[[http.services.service2.LoadBalancer.Servers]] [[http.services.service2.loadBalancer.servers]]
URL = "http://127.0.0.1:9020" url = "http://127.0.0.1:9020"
[[tls.certificates]] [[tls.certificates]]
certFile = "fixtures/https/snitest.com.cert" certFile = "fixtures/https/snitest.com.cert"

View file

@ -14,27 +14,29 @@ level = "DEBUG"
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
Service = "service1" service = "service1"
Rule = "Host(`snitest.com`)" rule = "Host(`snitest.com`)"
[http.routers.router1.tls] [http.routers.router1.tls]
[http.routers.router2] [http.routers.router2]
Service = "service2" service = "service2"
Rule = "Host(`snitest.org`)" rule = "Host(`snitest.org`)"
[http.routers.router2.tls] [http.routers.router2.tls]
[http.services] [http.services]
[http.services.service1] [http.services.service1]
[http.services.service1.LoadBalancer] [http.services.service1.loadBalancer]
[[http.services.service1.LoadBalancer.Servers]] [[http.services.service1.loadBalancer.servers]]
URL = "http://127.0.0.1:9010" url = "http://127.0.0.1:9010"
[http.services.service2] [http.services.service2]
[http.services.service2.LoadBalancer] [http.services.service2.loadBalancer]
[[http.services.service2.LoadBalancer.Servers]] [[http.services.service2.loadBalancer.servers]]
URL = "http://127.0.0.1:9020" url = "http://127.0.0.1:9020"
[[tls.certificates]] [[tls.certificates]]
certFile = "fixtures/https/snitest.com.cert" certFile = "fixtures/https/snitest.com.cert"
@ -45,5 +47,5 @@ level = "DEBUG"
keyFile = "fixtures/https/snitest.org.key" keyFile = "fixtures/https/snitest.org.key"
[tls.options] [tls.options]
[tls.options.default.ClientCA] [tls.options.default.clientCA]
files = ["fixtures/https/clientca/ca1and2.crt"] files = ["fixtures/https/clientca/ca1and2.crt"]

View file

@ -14,26 +14,28 @@ level = "DEBUG"
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
Service = "service1" service = "service1"
Rule = "Host(`snitest.com`)" rule = "Host(`snitest.com`)"
[http.routers.router1.tls] [http.routers.router1.tls]
[http.routers.router2] [http.routers.router2]
Service = "service2" service = "service2"
Rule = "Host(`snitest.org`)" rule = "Host(`snitest.org`)"
[http.routers.router2.tls] [http.routers.router2.tls]
[http.services] [http.services]
[http.services.service1] [http.services.service1]
[http.services.service1.LoadBalancer] [http.services.service1.loadBalancer]
[[http.services.service1.LoadBalancer.Servers]] [[http.services.service1.loadBalancer.servers]]
URL = "http://127.0.0.1:9010" url = "http://127.0.0.1:9010"
[http.services.service2] [http.services.service2]
[http.services.service2.LoadBalancer] [http.services.service2.loadBalancer]
[[http.services.service2.LoadBalancer.Servers]] [[http.services.service2.loadBalancer.servers]]
URL = "http://127.0.0.1:9020" url = "http://127.0.0.1:9020"
[[tls.certificates]] [[tls.certificates]]
certFile = "fixtures/https/snitest.com.cert" certFile = "fixtures/https/snitest.com.cert"
@ -44,6 +46,6 @@ level = "DEBUG"
keyFile = "fixtures/https/snitest.org.key" keyFile = "fixtures/https/snitest.org.key"
[tls.options] [tls.options]
[tls.options.default.ClientCA] [tls.options.default.clientCA]
files = ["fixtures/https/clientca/ca1.crt", "fixtures/https/clientca/ca2.crt"] files = ["fixtures/https/clientca/ca1.crt", "fixtures/https/clientca/ca2.crt"]
optional = false optional = false

View file

@ -11,13 +11,13 @@
[http.services] [http.services]
[http.services.service1] [http.services.service1]
[http.services.service1.LoadBalancer] [http.services.service1.loadBalancer]
[[http.services.service1.LoadBalancer.Servers]] [[http.services.service1.loadBalancer.servers]]
url = "http://127.0.0.1:9010" url = "http://127.0.0.1:9010"
[http.services.service2] [http.services.service2]
[http.services.service2.LoadBalancer] [http.services.service2.loadBalancer]
[[http.services.service2.LoadBalancer.Servers]] [[http.services.service2.loadBalancer.servers]]
url = "http://127.0.0.1:9020" url = "http://127.0.0.1:9020"
# bad certificates to validate the loop on the certificate appending # bad certificates to validate the loop on the certificate appending

View file

@ -14,6 +14,8 @@ level = "DEBUG"
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
service = "service1" service = "service1"
@ -27,8 +29,8 @@ level = "DEBUG"
[http.services] [http.services]
[http.services.service1] [http.services.service1]
[http.services.service1.LoadBalancer] [http.services.service1.loadBalancer]
[[http.services.service1.LoadBalancer.Servers]] [[http.services.service1.loadBalancer.servers]]
url = "http://127.0.0.1:9010" url = "http://127.0.0.1:9010"
[[tls.certificates]] [[tls.certificates]]
@ -40,6 +42,6 @@ level = "DEBUG"
keyFile = "fixtures/https/www.snitest.com.key" keyFile = "fixtures/https/www.snitest.com.key"
[tls.stores] [tls.stores]
[tls.stores.default.DefaultCertificate] [tls.stores.default.defaultCertificate]
certFile = "fixtures/https/snitest.com.cert" certFile = "fixtures/https/snitest.com.cert"
keyFile = "fixtures/https/snitest.com.key" keyFile = "fixtures/https/snitest.com.key"

View file

@ -17,6 +17,8 @@ level = "DEBUG"
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
entryPoints = [ "web" ] entryPoints = [ "web" ]
@ -139,27 +141,27 @@ level = "DEBUG"
[http.routers.router10TLS.tls] [http.routers.router10TLS.tls]
[http.middlewares] [http.middlewares]
[http.middlewares.api-strip.StripPrefix] [http.middlewares.api-strip.stripPrefix]
prefixes = ["/api"] prefixes = ["/api"]
[http.middlewares.api-slash-strip.StripPrefix] [http.middlewares.api-slash-strip.stripPrefix]
prefixes = ["/api/"] prefixes = ["/api/"]
[http.middlewares.foo-add-prefix.AddPrefix] [http.middlewares.foo-add-prefix.addPrefix]
prefix = "/foo" prefix = "/foo"
[http.middlewares.foo-slash-add-prefix.AddPrefix] [http.middlewares.foo-slash-add-prefix.addPrefix]
prefix = "/foo/" prefix = "/foo/"
[http.middlewares.id-strip-regex-prefix.StripPrefixRegex] [http.middlewares.id-strip-regex-prefix.stripPrefixRegex]
regex = ["/{id:[a-z]+}"] regex = ["/{id:[a-z]+}"]
[http.middlewares.id-slash-strip-regex-prefix.StripPrefixRegex] [http.middlewares.id-slash-strip-regex-prefix.stripPrefixRegex]
regex = ["/{id:[a-z]+}/"] regex = ["/{id:[a-z]+}/"]
[http.middlewares.api-regex-replace.ReplacePathRegex] [http.middlewares.api-regex-replace.replacePathRegex]
regex = "/api" regex = "/api"
replacement = "/" replacement = "/"
[http.middlewares.api-slash-regex-replace.ReplacePathRegex] [http.middlewares.api-slash-regex-replace.replacePathRegex]
regex = "/api/" regex = "/api/"
replacement = "/" replacement = "/"
[http.middlewares.api-replace-path.ReplacePath] [http.middlewares.api-replace-path.replacePath]
path = "/api" path = "/api"
[http.middlewares.api-slash-replace-path.ReplacePath] [http.middlewares.api-slash-replace-path.replacePath]
path = "/api/" path = "/api/"
[http.middlewares.redirect-https.redirectScheme] [http.middlewares.redirect-https.redirectScheme]
scheme = "https" scheme = "https"
@ -167,6 +169,6 @@ level = "DEBUG"
[http.services] [http.services]
[http.services.service1] [http.services.service1]
[http.services.service1.LoadBalancer] [http.services.service1.loadBalancer]
[[http.services.service1.LoadBalancer.Servers]] [[http.services.service1.loadBalancer.servers]]
url = "http://127.0.0.1:80" url = "http://127.0.0.1:80"

View file

@ -14,27 +14,29 @@ level = "DEBUG"
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
Service = "service1" service = "service1"
Rule = "Host(`snitest.com`)" rule = "Host(`snitest.com`)"
[http.routers.router1.tls] [http.routers.router1.tls]
[http.routers.router2] [http.routers.router2]
Service = "service2" service = "service2"
Rule = "Host(`snitest.org`)" rule = "Host(`snitest.org`)"
[http.routers.router2.tls] [http.routers.router2.tls]
[http.services] [http.services]
[http.services.service1] [http.services.service1]
[http.services.service1.LoadBalancer] [http.services.service1.loadBalancer]
[[http.services.service1.LoadBalancer.Servers]] [[http.services.service1.loadBalancer.servers]]
URL = "http://127.0.0.1:9010" url = "http://127.0.0.1:9010"
[http.services.service2] [http.services.service2]
[http.services.service2.LoadBalancer] [http.services.service2.loadBalancer]
[[http.services.service2.LoadBalancer.Servers]] [[http.services.service2.loadBalancer.servers]]
URL = "http://127.0.0.1:9020" url = "http://127.0.0.1:9020"
[[tls.certificates]] [[tls.certificates]]
certFile = "fixtures/https/snitest.com.cert" certFile = "fixtures/https/snitest.com.cert"

View file

@ -14,6 +14,8 @@ level = "DEBUG"
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
rule = "HostRegexp(`{subdomain:[a-z1-9-]+}.snitest.com`)" rule = "HostRegexp(`{subdomain:[a-z1-9-]+}.snitest.com`)"
@ -27,8 +29,8 @@ level = "DEBUG"
[http.services] [http.services]
[http.services.service1] [http.services.service1]
[http.services.service1.LoadBalancer] [http.services.service1.loadBalancer]
[[http.services.service1.LoadBalancer.Servers]] [[http.services.service1.loadBalancer.servers]]
url = "http://127.0.0.1:9010" url = "http://127.0.0.1:9010"
[[tls.certificates]] [[tls.certificates]]
@ -36,6 +38,6 @@ level = "DEBUG"
keyFile = "fixtures/https/uppercase_wildcard.www.snitest.com.key" keyFile = "fixtures/https/uppercase_wildcard.www.snitest.com.key"
[tls.stores] [tls.stores]
[tls.stores.default.DefaultCertificate] [tls.stores.default.defaultCertificate]
certFile = "fixtures/https/wildcard.snitest.com.cert" certFile = "fixtures/https/wildcard.snitest.com.cert"
keyFile = "fixtures/https/wildcard.snitest.com.key" keyFile = "fixtures/https/wildcard.snitest.com.key"

View file

@ -14,6 +14,8 @@ level = "DEBUG"
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
service = "service1" service = "service1"
@ -27,8 +29,8 @@ level = "DEBUG"
[http.services] [http.services]
[http.services.service1] [http.services.service1]
[http.services.service1.LoadBalancer] [http.services.service1.loadBalancer]
[[http.services.service1.LoadBalancer.Servers]] [[http.services.service1.loadBalancer.servers]]
url = "http://127.0.0.1:9010" url = "http://127.0.0.1:9010"
[[tls.certificates]] [[tls.certificates]]
@ -40,6 +42,6 @@ level = "DEBUG"
keyFile = "fixtures/https/www.snitest.com.key" keyFile = "fixtures/https/www.snitest.com.key"
[tls.stores] [tls.stores]
[tls.stores.default.DefaultCertificate] [tls.stores.default.defaultCertificate]
certFile = "fixtures/https/snitest.com.cert" certFile = "fixtures/https/snitest.com.cert"
keyFile = "fixtures/https/snitest.com.key" keyFile = "fixtures/https/snitest.com.key"

View file

@ -14,6 +14,8 @@
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
service = "service1" service = "service1"
@ -22,8 +24,8 @@
[http.services] [http.services]
[http.services.service1] [http.services.service1]
[http.services.service1.LoadBalancer] [http.services.service1.loadBalancer]
[[http.services.service1.LoadBalancer.Servers]] [[http.services.service1.loadBalancer.servers]]
url = "http://127.0.0.1:9010" url = "http://127.0.0.1:9010"
[tls.options] [tls.options]
@ -32,7 +34,7 @@
[tls.stores] [tls.stores]
[tls.stores.default] [tls.stores.default]
[tls.stores.default.DefaultCertificate] [tls.stores.default.defaultCertificate]
certFile = "fixtures/https/snitest.com.cert" certFile = "fixtures/https/snitest.com.cert"
keyFile = "fixtures/https/snitest.com.key" keyFile = "fixtures/https/snitest.com.key"

View file

@ -14,35 +14,37 @@ level = "DEBUG"
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
Service = "service1" service = "service1"
Rule = "Host(`snitest.com`)" rule = "Host(`snitest.com`)"
[http.routers.router1.tls] [http.routers.router1.tls]
options = "foo" options = "foo"
[http.routers.router2] [http.routers.router2]
Service = "service2" service = "service2"
Rule = "Host(`snitest.org`)" rule = "Host(`snitest.org`)"
[http.routers.router2.tls] [http.routers.router2.tls]
options = "bar" options = "bar"
[http.routers.router3] [http.routers.router3]
Service = "service2" service = "service2"
Rule = "Host(`snitest.org`)" rule = "Host(`snitest.org`)"
[http.routers.router3.tls] [http.routers.router3.tls]
options = "unknown" options = "unknown"
[http.services] [http.services]
[http.services.service1] [http.services.service1]
[http.services.service1.LoadBalancer] [http.services.service1.loadBalancer]
[[http.services.service1.LoadBalancer.Servers]] [[http.services.service1.loadBalancer.servers]]
URL = "http://127.0.0.1:9010" url = "http://127.0.0.1:9010"
[http.services.service2] [http.services.service2]
[http.services.service2.LoadBalancer] [http.services.service2.loadBalancer]
[[http.services.service2.LoadBalancer.Servers]] [[http.services.service2.loadBalancer.servers]]
URL = "http://127.0.0.1:9020" url = "http://127.0.0.1:9020"
[[tls.certificates]] [[tls.certificates]]
certFile = "fixtures/https/snitest.com.cert" certFile = "fixtures/https/snitest.com.cert"

View file

@ -33,14 +33,16 @@ fblo6RBxUQ==
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
Service = "service1" service = "service1"
Rule = "Path(`/ping`)" rule = "Path(`/ping`)"
[http.services] [http.services]
[http.services.service1] [http.services.service1]
[http.services.service1.LoadBalancer] [http.services.service1.loadBalancer]
[[http.services.service1.LoadBalancer.Servers]] [[http.services.service1.loadBalancer.servers]]
URL = "{{ .BackendHost }}" url = "{{ .BackendHost }}"

View file

@ -18,14 +18,16 @@ rootCAs = [ "fixtures/https/rootcas/local.crt"]
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
Service = "service1" service = "service1"
Rule = "Path(`/ping`)" rule = "Path(`/ping`)"
[http.services] [http.services]
[http.services.service1] [http.services.service1]
[http.services.service1.LoadBalancer] [http.services.service1.loadBalancer]
[[http.services.service1.LoadBalancer.Servers]] [[http.services.service1.loadBalancer.servers]]
URL = "{{ .BackendHost }}" url = "{{ .BackendHost }}"

View file

@ -5,14 +5,12 @@ sendAnonymousUsage = false
[log] [log]
level = "DEBUG" level = "DEBUG"
[entryPoints]
[entryPoints.web]
address = ":8000"
[entryPoints.footcp]
address = ":8093"
[api] [api]
[Providers] [entryPoints]
[Providers.KubernetesCRD] [entryPoints.footcp]
address = ":8093"
[entryPoints.web]
address = ":8000"
[providers.kubernetesCRD]

View file

@ -2,6 +2,8 @@
checkNewVersion = false checkNewVersion = false
sendAnonymousUsage = false sendAnonymousUsage = false
[api]
[log] [log]
level = "DEBUG" level = "DEBUG"
@ -9,7 +11,4 @@ level = "DEBUG"
[entryPoints.web] [entryPoints.web]
address = ":8000" address = ":8000"
[api] [providers.kubernetes]
[Providers]
[Providers.Kubernetes]

View file

@ -21,17 +21,16 @@ entryPoint = "api"
[providers] [providers]
[providers.file] [providers.file]
################################################################ ## dynamic configuration ##
# rules
################################################################
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
Service = "service1" Service = "service1"
Rule = "Path(`/test1`)" rule = "Path(`/test1`)"
[http.services] [http.services]
[http.services.service1] [http.services.service1]
[http.services.service1.LoadBalancer] [http.services.service1.loadBalancer]
[[http.services.service1.LoadBalancer.Servers]] [[http.services.service1.loadBalancer.servers]]
URL = "http://127.0.0.1:8081" url = "http://127.0.0.1:8081"

View file

@ -13,20 +13,19 @@ level = "DEBUG"
[providers] [providers]
[providers.docker] [providers.docker]
endpoint = "unix:///var/run/docker.sock"
watch = true watch = true
exposedByDefault = false exposedByDefault = false
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router-1] [http.routers.router-1]
Service = "service-test" service = "service-test"
Rule = "PathPrefix(`/file`)" rule = "PathPrefix(`/file`)"
[http.services] [http.services]
[http.services.service-test] [http.services.service-test.loadBalancer]
[http.services.service-test.LoadBalancer] [[http.services.service-test.loadBalancer.servers]]
url = "http://{{ .IP }}"
[[http.services.service-test.LoadBalancer.Servers]]
URL = "http://{{ .IP }}"

View file

@ -11,17 +11,18 @@ level = "DEBUG"
[entryPoints.web] [entryPoints.web]
address = ":8000" address = ":8000"
[Providers] [providers]
[Providers.Rest] [providers.rest]
[Providers.File] [providers.file]
## dynamic configuration ##
[http.services] [http.services]
[http.services.service] [http.services.service.loadBalancer]
[http.services.service.LoadBalancer] [[http.services.service.loadBalancer.servers]]
url = "{{.Server}}"
[[http.services.service.LoadBalancer.Servers]]
URL = "{{.Server}}"
[http.middlewares] [http.middlewares]
[http.middlewares.customheader.Headers.CustomRequestHeaders] [http.middlewares.customheader.headers.customRequestHeaders]
X-Custom="CustomValue" X-Custom="CustomValue"

View file

@ -16,14 +16,16 @@ level = "DEBUG"
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
Service = "service1" service = "service1"
Rule = "Path(`/whoami`)" rule = "Path(`/whoami`)"
[http.services] [http.services]
[http.services.service1] [http.services.service1]
[http.services.service1.LoadBalancer] [http.services.service1.loadBalancer]
[[http.services.service1.LoadBalancer.Servers]] [[http.services.service1.loadBalancer.servers]]
URL = "http://{{.WhoamiIP}}" url = "http://{{.WhoamiIP}}"

View file

@ -16,14 +16,16 @@ level = "DEBUG"
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
Service = "service1" service = "service1"
Rule = "Path(`/whoami`)" rule = "Path(`/whoami`)"
[http.services] [http.services]
[http.services.service1] [http.services.service1]
[http.services.service1.LoadBalancer] [http.services.service1.loadBalancer]
[[http.services.service1.LoadBalancer.Servers]] [[http.services.service1.loadBalancer.servers]]
URL = "http://{{.WhoamiIP}}" url = "http://{{.WhoamiIP}}"

View file

@ -12,34 +12,35 @@ level = "DEBUG"
[entryPoints.web] [entryPoints.web]
address = ":8081" address = ":8081"
[entryPoints.api] [entryPoints.api]
address = ":8080" address = ":8080"
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
Service = "service1" service = "service1"
Middlewares = [ "ratelimit" ] middlewares = [ "ratelimit" ]
Rule = "Path(`/`)" rule = "Path(`/`)"
[http.middlewares] [http.middlewares]
[http.middlewares.ratelimit.RateLimit] [http.middlewares.ratelimit.rateLimit]
extractorfunc = "client.ip" extractorfunc = "client.ip"
[http.middlewares.ratelimit.RateLimit.rateset.rateset1] [http.middlewares.ratelimit.rateLimit.rateSet.rateset1]
period = "60s" period = "60s"
average = 4 average = 4
burst = 5 burst = 5
[http.middlewares.ratelimit.RateLimit.rateset.rateset2] [http.middlewares.ratelimit.rateLimit.rateSet.rateset2]
period = "3s" period = "3s"
average = 1 average = 1
burst = 2 burst = 2
[http.services] [http.services]
[http.services.service1] [http.services.service1]
[http.services.service1.LoadBalancer] [http.services.service1.loadBalancer]
passHostHeader = true passHostHeader = true
[[http.services.service1.LoadBalancer.Servers]] [[http.services.service1.loadBalancer.servers]]
URL = "http://{{.Server1}}:80" url = "http://{{.Server1}}:80"

View file

@ -6,30 +6,31 @@ sendAnonymousUsage = false
level = "DEBUG" level = "DEBUG"
[entryPoints] [entryPoints]
[entryPoints.web] [entryPoints.web]
address = ":8000" address = ":8000"
[entryPoints.web.transport.lifeCycle] [entryPoints.web.transport.lifeCycle]
RequestAcceptGraceTimeout = "10s" requestAcceptGraceTimeout = "10s"
[entryPoints.traefik] [entryPoints.traefik]
address = ":8001" address = ":8001"
[entryPoints.traefik.transport.lifeCycle] [entryPoints.traefik.transport.lifeCycle]
RequestAcceptGraceTimeout = "10s" requestAcceptGraceTimeout = "10s"
[ping] [ping]
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router] [http.routers.router]
Service = "service" service = "service"
Rule = "Path(`/service`)" rule = "Path(`/service`)"
[http.services] [http.services]
[http.services.service] [http.services.service.loadBalancer]
[http.services.service.LoadBalancer] [[http.services.service.loadBalancer.servers]]
url = "{{.Server}}"
[[http.services.service.LoadBalancer.Servers]]
URL = "{{.Server}}"

View file

@ -14,21 +14,23 @@ level = "DEBUG"
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
Service = "service1" service = "service1"
Middlewares = [ "retry" ] middlewares = [ "retry" ]
Rule = "PathPrefix(`/`)" rule = "PathPrefix(`/`)"
[http.middlewares.retry.Retry] [http.middlewares.retry.retry]
Attempts = 3 attempts = 3
[http.services] [http.services]
[http.services.service1] [http.services.service1]
[http.services.service1.LoadBalancer] [http.services.service1.loadBalancer]
[[http.services.service1.LoadBalancer.Servers]] [[http.services.service1.loadBalancer.servers]]
URL = "http://{{.WhoamiEndpoint}}:8080" url = "http://{{.WhoamiEndpoint}}:8080"
[[http.services.service1.LoadBalancer.Servers]] [[http.services.service1.loadBalancer.servers]]
URL = "http://{{.WhoamiEndpoint}}:80" url = "http://{{.WhoamiEndpoint}}:80"

View file

@ -20,5 +20,5 @@ level = "DEBUG"
[providers.file] [providers.file]
[http.middlewares] [http.middlewares]
[http.middlewares.authentication.basicauth] [http.middlewares.authentication.basicAuth]
users = ["test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/", "test2:$apr1$d9hr9HBB$4HxwgUir3HP4EsggP/QNo0"] users = ["test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/", "test2:$apr1$d9hr9HBB$4HxwgUir3HP4EsggP/QNo0"]

View file

@ -11,27 +11,26 @@ level = "DEBUG"
[api] [api]
[providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
EntryPoints = ["web"] entryPoints = ["web"]
Service = "service1" service = "service1"
Rule = "PathPrefix(`/whoami`)" rule = "PathPrefix(`/whoami`)"
[http.routers.router2] [http.routers.router2]
EntryPoints = ["traefik"] entryPoints = ["traefik"]
Service = "service2" service = "service2"
Rule = "PathPrefix(`/whoami`)" rule = "PathPrefix(`/whoami`)"
[http.services] [http.services]
[http.services.service1] [http.services.service1.loadBalancer]
[http.services.service1.LoadBalancer] [[http.services.service1.loadBalancer.servers]]
[[http.services.service1.LoadBalancer.Servers]] url = "{{ .Server1 }}"
URL = "{{ .Server1 }}"
[http.services.service2] [http.services.service2.loadBalancer]
[http.services.service2.LoadBalancer] [[http.services.service2.loadBalancer.servers]]
[[http.services.service2.LoadBalancer.Servers]] url = "{{ .Server2 }}"
URL = "{{ .Server2 }}"

View file

@ -13,6 +13,8 @@ level = "DEBUG"
[providers.file] [providers.file]
## dynamic configuration ##
[tcp] [tcp]
[tcp.routers] [tcp.routers]
[tcp.routers.to-whoami-no-tls] [tcp.routers.to-whoami-no-tls]
@ -21,8 +23,8 @@ level = "DEBUG"
service = "whoami-no-tls" service = "whoami-no-tls"
[tcp.services] [tcp.services]
[tcp.services.whoami-no-tls.loadbalancer] [tcp.services.whoami-no-tls.loadBalancer]
[[tcp.services.whoami-no-tls.loadbalancer.servers]] [[tcp.services.whoami-no-tls.loadBalancer.servers]]
address = "localhost:8086" address = "localhost:8086"
[http] [http]
@ -33,8 +35,7 @@ level = "DEBUG"
service = "whoami" service = "whoami"
[http.routers.to-whoami.tls] [http.routers.to-whoami.tls]
[http.services] [http.services]
[http.services.whoami.loadbalancer] [http.services.whoami.loadBalancer]
[[http.services.whoami.loadbalancer.servers]] [[http.services.whoami.loadBalancer.servers]]
url = "http://localhost:8085" url = "http://localhost:8085"

View file

@ -13,6 +13,8 @@ level = "DEBUG"
[providers.file] [providers.file]
## dynamic configuration ##
[tcp] [tcp]
[tcp.routers] [tcp.routers]
[tcp.routers.to-whoami-no-tls] [tcp.routers.to-whoami-no-tls]
@ -21,6 +23,6 @@ level = "DEBUG"
service = "whoami-no-tls" service = "whoami-no-tls"
[tcp.services] [tcp.services]
[tcp.services.whoami-no-tls.loadbalancer] [tcp.services.whoami-no-tls.loadBalancer]
[[tcp.services.whoami-no-tls.loadbalancer.servers]] [[tcp.services.whoami-no-tls.loadBalancer.servers]]
address = "localhost:8086" address = "localhost:8086"

View file

@ -13,6 +13,8 @@ level = "DEBUG"
[providers.file] [providers.file]
## dynamic configuration ##
[http] [http]
[http.routers] [http.routers]
[http.routers.my-router] [http.routers.my-router]
@ -27,8 +29,8 @@ level = "DEBUG"
[http.routers.my-https-router.tls] [http.routers.my-https-router.tls]
[http.services] [http.services]
[http.services.whoami.loadbalancer] [http.services.whoami.loadBalancer]
[[http.services.whoami.loadbalancer.servers]] [[http.services.whoami.loadBalancer.servers]]
url = "http://localhost:8085" url = "http://localhost:8085"
[tcp] [tcp]
[tcp.routers] [tcp.routers]
@ -52,16 +54,16 @@ level = "DEBUG"
entryPoints = [ "tcp" ] entryPoints = [ "tcp" ]
[tcp.routers.to-whoami-no-cert.tls] [tcp.routers.to-whoami-no-cert.tls]
[tcp.services.whoami-a.loadbalancer] [tcp.services.whoami-a.loadBalancer]
[[tcp.services.whoami-a.loadbalancer.servers]] [[tcp.services.whoami-a.loadBalancer.servers]]
address = "localhost:8081" address = "localhost:8081"
[tcp.services.whoami-b.loadbalancer] [tcp.services.whoami-b.loadBalancer]
[[tcp.services.whoami-b.loadbalancer.servers]] [[tcp.services.whoami-b.loadBalancer.servers]]
address = "localhost:8082" address = "localhost:8082"
[tcp.services.whoami-no-cert.loadbalancer] [tcp.services.whoami-no-cert.loadBalancer]
[[tcp.services.whoami-no-cert.loadbalancer.servers]] [[tcp.services.whoami-no-cert.loadBalancer.servers]]
address = "localhost:8083" address = "localhost:8083"
[[tls.certificates]] [[tls.certificates]]

View file

@ -13,6 +13,8 @@ level = "DEBUG"
[providers.file] [providers.file]
## dynamic configuration ##
[tcp] [tcp]
[tcp.routers] [tcp.routers]
[tcp.routers.to-whoami-no-cert] [tcp.routers.to-whoami-no-cert]
@ -30,9 +32,9 @@ level = "DEBUG"
options = "bar" options = "bar"
[tcp.services.whoami-no-cert] [tcp.services.whoami-no-cert]
[tcp.services.whoami-no-cert.loadbalancer] [tcp.services.whoami-no-cert.loadBalancer]
method = "wrr" method = "wrr"
[[tcp.services.whoami-no-cert.loadbalancer.servers]] [[tcp.services.whoami-no-cert.loadBalancer.servers]]
address = "localhost:8083" address = "localhost:8083"
[tls.options] [tls.options]

View file

@ -41,18 +41,18 @@ level = "DEBUG"
service = "whoami-no-tls" service = "whoami-no-tls"
[tcp.services] [tcp.services]
[tcp.services.whoami-no-tls.loadbalancer] [tcp.services.whoami-no-tls.loadBalancer]
[[tcp.services.whoami-no-tls.loadbalancer.servers]] [[tcp.services.whoami-no-tls.loadBalancer.servers]]
address = "localhost:8084" address = "localhost:8084"
[tcp.services.whoami-a.loadbalancer] [tcp.services.whoami-a.loadBalancer]
[[tcp.services.whoami-a.loadbalancer.servers]] [[tcp.services.whoami-a.loadBalancer.servers]]
address = "localhost:8081" address = "localhost:8081"
[tcp.services.whoami-b.loadbalancer] [tcp.services.whoami-b.loadBalancer]
[[tcp.services.whoami-b.loadbalancer.servers]] [[tcp.services.whoami-b.loadBalancer.servers]]
address = "localhost:8082" address = "localhost:8082"
[tcp.services.whoami-no-cert.loadbalancer] [tcp.services.whoami-no-cert.loadBalancer]
[[tcp.services.whoami-no-cert.loadbalancer.servers]] [[tcp.services.whoami-no-cert.loadBalancer.servers]]
address = "localhost:8083" address = "localhost:8083"

View file

@ -13,6 +13,8 @@ level = "DEBUG"
[providers.file] [providers.file]
## dynamic configuration ##
[tcp] [tcp]
[tcp.routers] [tcp.routers]
[tcp.routers.to-whoami-no-tls] [tcp.routers.to-whoami-no-tls]
@ -21,6 +23,6 @@ level = "DEBUG"
service = "whoami-no-tls" service = "whoami-no-tls"
[tcp.services] [tcp.services]
[tcp.services.whoami-no-tls.loadbalancer] [tcp.services.whoami-no-tls.loadBalancer]
[[tcp.services.whoami-no-tls.loadbalancer.servers]] [[tcp.services.whoami-no-tls.loadBalancer.servers]]
address = "localhost:8084" address = "localhost:8084"

View file

@ -21,22 +21,24 @@ level = "DEBUG"
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
Service = "service1" service = "service1"
Rule = "Path(`/dialTimeout`)" rule = "Path(`/dialTimeout`)"
[http.routers.router2] [http.routers.router2]
Service = "service2" service = "service2"
Rule = "Path(`/responseHeaderTimeout`)" rule = "Path(`/responseHeaderTimeout`)"
[http.services] [http.services]
[http.services.service1] [http.services.service1]
[http.services.service1.LoadBalancer] [http.services.service1.loadBalancer]
[[http.services.service1.LoadBalancer.Servers]] [[http.services.service1.loadBalancer.servers]]
URL = "http://50.255.255.1" url = "http://50.255.255.1"
[http.services.service2] [http.services.service2]
[http.services.service2.LoadBalancer] [http.services.service2.loadBalancer]
[[http.services.service2.LoadBalancer.Servers]] [[http.services.service2.loadBalancer.servers]]
URL = "http://{{.TimeoutEndpoint}}:9000" url = "http://{{.TimeoutEndpoint}}:9000"

View file

@ -17,15 +17,17 @@ level = "DEBUG"
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
Service = "keepalive" service = "keepalive"
Rule = "PathPrefix(`/keepalive`)" rule = "PathPrefix(`/keepalive`)"
[http.services] [http.services]
[http.services.keepalive] [http.services.keepalive]
[http.services.keepalive.LoadBalancer] [http.services.keepalive.loadBalancer]
passHostHeader = true passHostHeader = true
[[http.services.keepalive.LoadBalancer.Servers]] [[http.services.keepalive.loadBalancer.servers]]
URL = "{{ .KeepAliveServer }}" url = "{{ .KeepAliveServer }}"
Weight = 1 weight = 1

View file

@ -16,17 +16,18 @@
[providers] [providers]
[providers.docker] [providers.docker]
endpoint = "unix:///var/run/docker.sock"
watch = true watch = true
[providers.file] [providers.file]
## dynamic configuration ##
[tls.options] [tls.options]
[tls.options.default.ClientCA] [tls.options.default.clientCA]
files = [ """{{ .RootCertContent }}""" ] files = [ """{{ .RootCertContent }}""" ]
optional = false optional = false
[tls.stores] [tls.stores]
[tls.stores.default.DefaultCertificate] [tls.stores.default.defaultCertificate]
certFile = """{{ .ServerCertContent }}""" certFile = """{{ .ServerCertContent }}"""
keyFile = """{{ .ServerKeyContent }}""" keyFile = """{{ .ServerKeyContent }}"""

View file

@ -22,6 +22,8 @@ level = "DEBUG"
[providers] [providers]
[providers.file] [providers.file]
## dynamic configuration ##
[http.routers] [http.routers]
[http.routers.router1] [http.routers.router1]
Service = "service1" Service = "service1"
@ -39,15 +41,15 @@ level = "DEBUG"
[http.middlewares] [http.middlewares]
[http.middlewares.retry.retry] [http.middlewares.retry.retry]
attempts = 3 attempts = 3
[http.middlewares.basic-auth.BasicAuth] [http.middlewares.basic-auth.basicAuth]
users = ["test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/", "test2:$apr1$d9hr9HBB$4HxwgUir3HP4EsggP/QNo0"] users = ["test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/", "test2:$apr1$d9hr9HBB$4HxwgUir3HP4EsggP/QNo0"]
[http.middlewares.ratelimit.RateLimit] [http.middlewares.ratelimit.rateLimit]
extractorfunc = "client.ip" extractorfunc = "client.ip"
[http.middlewares.ratelimit.RateLimit.rateset.rateset1] [http.middlewares.ratelimit.rateLimit.rateSet.rateset1]
period = "60s" period = "60s"
average = 4 average = 4
burst = 5 burst = 5
[http.middlewares.ratelimit.RateLimit.rateset.rateset2] [http.middlewares.ratelimit.rateLimit.rateSet.rateset2]
period = "3s" period = "3s"
average = 1 average = 1
burst = 2 burst = 2
@ -55,19 +57,19 @@ level = "DEBUG"
[http.services] [http.services]
[http.services.service1] [http.services.service1]
[http.services.service1.LoadBalancer] [http.services.service1.loadBalancer]
passHostHeader = true passHostHeader = true
[[http.services.service1.LoadBalancer.Servers]] [[http.services.service1.loadBalancer.servers]]
URL = "http://{{.WhoAmiIP}}:{{.WhoAmiPort}}" url = "http://{{.WhoAmiIP}}:{{.WhoAmiPort}}"
[http.services.service2] [http.services.service2]
passHostHeader = true passHostHeader = true
[http.services.service2.LoadBalancer] [http.services.service2.loadBalancer]
[[http.services.service2.LoadBalancer.Servers]] [[http.services.service2.loadBalancer.servers]]
URL = "http://{{.WhoAmiIP}}:{{.WhoAmiPort}}" url = "http://{{.WhoAmiIP}}:{{.WhoAmiPort}}"
[http.services.service3] [http.services.service3]
passHostHeader = true passHostHeader = true
[http.services.service3.LoadBalancer] [http.services.service3.loadBalancer]
[[http.services.service3.LoadBalancer.Servers]] [[http.services.service3.loadBalancer.servers]]
URL = "http://{{.WhoAmiIP}}:{{.WhoAmiPort}}" url = "http://{{.WhoAmiIP}}:{{.WhoAmiPort}}"

Some files were not shown because too many files have changed in this diff Show more