2019-02-26 05:50:07 -08:00
|
|
|
# Overview
|
|
|
|
|
|
|
|
Traefik's Many Friends
|
|
|
|
{: .subtitle }
|
|
|
|
|
|
|
|
![Providers](../assets/img/providers.png)
|
|
|
|
|
|
|
|
Configuration discovery in Traefik is achieved through _Providers_.
|
|
|
|
|
|
|
|
The _providers_ are existing infrastructure components, whether orchestrators, container engines, cloud providers, or key-value stores.
|
2019-03-19 16:44:06 +01:00
|
|
|
The idea is that Traefik will query the providers' API in order to find relevant information about routing,
|
|
|
|
and each time Traefik detects a change, it dynamically updates the routes.
|
2019-02-26 05:50:07 -08:00
|
|
|
|
|
|
|
Deploy and forget is Traefik's credo.
|
|
|
|
|
|
|
|
## Orchestrators
|
|
|
|
|
|
|
|
Even if each provider is different, we can categorize them in four groups:
|
|
|
|
|
|
|
|
- Label based (each deployed container has a set of labels attached to it)
|
|
|
|
- Key-Value based (each deployed container updates a key-value store with relevant information)
|
|
|
|
- Annotation based (a separate object, with annotations, defines the characteristics of the container)
|
|
|
|
- File based (the good old configuration file)
|
|
|
|
|
2020-10-16 01:54:04 +13:00
|
|
|
## Provider Namespace
|
|
|
|
|
|
|
|
When you declare certain objects, in Traefik dynamic configuration,
|
|
|
|
such as middleware, service, TLS options or servers transport, they live in its provider's namespace.
|
|
|
|
For example, if you declare a middleware using a Docker label, under the hoods, it will reside in the docker provider namespace.
|
|
|
|
|
|
|
|
If you use multiple providers and wish to reference such an object declared in another provider
|
|
|
|
(aka referencing a cross-provider object, e.g. middleware), then you'll have to append the `@` separator,
|
|
|
|
followed by the provider name to the object name.
|
|
|
|
|
|
|
|
```text
|
|
|
|
<resource-name>@<provider-name>
|
|
|
|
```
|
|
|
|
|
|
|
|
!!! important "Kubernetes Namespace"
|
|
|
|
|
|
|
|
As Kubernetes also has its own notion of namespace,
|
|
|
|
one should not confuse the "provider namespace" with the "kubernetes namespace" of a resource when in the context of a cross-provider usage.
|
|
|
|
In this case, since the definition of a traefik dynamic configuration object is not in kubernetes,
|
|
|
|
specifying a "kubernetes namespace" when referring to the resource does not make any sense,
|
|
|
|
and therefore this specification would be ignored even if present.
|
|
|
|
On the other hand, if you, say, declare a middleware as a Custom Resource in Kubernetes and use the non-crd Ingress objects,
|
|
|
|
you'll have to add the Kubernetes namespace of the middleware to the annotation like this `<middleware-namespace>-<middleware-name>@kubernetescrd`.
|
|
|
|
|
2020-10-21 00:02:04 +07:00
|
|
|
!!! abstract "Referencing a Traefik dynamic configuration object from Another Provider"
|
2020-10-16 01:54:04 +13:00
|
|
|
|
|
|
|
Declaring the add-foo-prefix in the file provider.
|
|
|
|
|
|
|
|
```toml tab="File (TOML)"
|
|
|
|
[http.middlewares]
|
|
|
|
[http.middlewares.add-foo-prefix.addPrefix]
|
|
|
|
prefix = "/foo"
|
|
|
|
```
|
|
|
|
|
|
|
|
```yaml tab="File (YAML)"
|
|
|
|
http:
|
|
|
|
middlewares:
|
|
|
|
add-foo-prefix:
|
|
|
|
addPrefix:
|
|
|
|
prefix: "/foo"
|
|
|
|
```
|
|
|
|
|
|
|
|
Using the add-foo-prefix middleware from other providers:
|
|
|
|
|
|
|
|
```yaml tab="Docker"
|
|
|
|
your-container: #
|
|
|
|
image: your-docker-image
|
|
|
|
|
|
|
|
labels:
|
|
|
|
# Attach add-foo-prefix@file middleware (declared in file)
|
|
|
|
- "traefik.http.routers.my-container.middlewares=add-foo-prefix@file"
|
|
|
|
```
|
|
|
|
|
|
|
|
```yaml tab="Kubernetes Ingress Route"
|
|
|
|
apiVersion: traefik.containo.us/v1alpha1
|
|
|
|
kind: IngressRoute
|
|
|
|
metadata:
|
|
|
|
name: ingressroutestripprefix
|
|
|
|
|
|
|
|
spec:
|
|
|
|
entryPoints:
|
|
|
|
- web
|
|
|
|
routes:
|
|
|
|
- match: Host(`example.com`)
|
|
|
|
kind: Rule
|
|
|
|
services:
|
|
|
|
- name: whoami
|
|
|
|
port: 80
|
|
|
|
middlewares:
|
|
|
|
- name: add-foo-prefix@file
|
|
|
|
# namespace: bar
|
|
|
|
# A namespace specification such as above is ignored
|
|
|
|
# when the cross-provider syntax is used.
|
|
|
|
```
|
|
|
|
|
|
|
|
```yaml tab="Kubernetes Ingress"
|
|
|
|
apiVersion: traefik.containo.us/v1alpha1
|
|
|
|
kind: Middleware
|
|
|
|
metadata:
|
|
|
|
name: stripprefix
|
|
|
|
namespace: appspace
|
|
|
|
spec:
|
|
|
|
stripPrefix:
|
|
|
|
prefixes:
|
|
|
|
- /stripit
|
|
|
|
|
|
|
|
---
|
|
|
|
apiVersion: networking.k8s.io/v1
|
|
|
|
kind: Ingress
|
|
|
|
metadata:
|
|
|
|
name: ingress
|
|
|
|
namespace: appspace
|
|
|
|
annotations:
|
|
|
|
# referencing a middleware from Kubernetes CRD provider:
|
|
|
|
# <middleware-namespace>-<middleware-name>@kubernetescrd
|
|
|
|
"traefik.ingress.kubernetes.io/router.middlewares": appspace-stripprefix@kubernetescrd
|
|
|
|
spec:
|
|
|
|
# ... regular ingress definition
|
|
|
|
```
|
|
|
|
|
2019-02-26 05:50:07 -08:00
|
|
|
## Supported Providers
|
|
|
|
|
|
|
|
Below is the list of the currently supported providers in Traefik.
|
|
|
|
|
2020-01-17 17:30:07 +01:00
|
|
|
| Provider | Type | Configuration Type |
|
|
|
|
|---------------------------------------|--------------|----------------------------|
|
|
|
|
| [Docker](./docker.md) | Orchestrator | Label |
|
|
|
|
| [Kubernetes](./kubernetes-crd.md) | Orchestrator | Custom Resource or Ingress |
|
|
|
|
| [Consul Catalog](./consul-catalog.md) | Orchestrator | Label |
|
2021-01-04 15:28:03 +05:30
|
|
|
| [ECS](./ecs.md) | Orchestrator | Label |
|
2020-01-17 17:30:07 +01:00
|
|
|
| [Marathon](./marathon.md) | Orchestrator | Label |
|
|
|
|
| [Rancher](./rancher.md) | Orchestrator | Label |
|
|
|
|
| [File](./file.md) | Manual | TOML/YAML format |
|
|
|
|
| [Consul](./consul.md) | KV | KV |
|
2020-07-15 16:56:03 +02:00
|
|
|
| [Etcd](./etcd.md) | KV | KV |
|
2020-01-17 17:30:07 +01:00
|
|
|
| [ZooKeeper](./zookeeper.md) | KV | KV |
|
2021-01-04 15:28:03 +05:30
|
|
|
| [Redis](./redis.md) | KV | KV |
|
2020-07-15 16:56:03 +02:00
|
|
|
| [HTTP](./http.md) | Manual | JSON format |
|
2019-02-26 05:50:07 -08:00
|
|
|
|
2019-09-23 14:32:04 +02:00
|
|
|
!!! info "More Providers"
|
2019-02-26 05:50:07 -08:00
|
|
|
|
2019-09-23 14:32:04 +02:00
|
|
|
The current version of Traefik doesn't support (yet) every provider.
|
2020-09-23 10:20:04 +02:00
|
|
|
See the [previous version (v1.7)](https://doc.traefik.io/traefik/v1.7/) for more providers.
|
2019-04-15 18:22:07 +02:00
|
|
|
|
2019-09-30 18:24:05 +02:00
|
|
|
### Configuration reload frequency
|
|
|
|
|
|
|
|
In some cases, some providers might undergo a sudden burst of changes,
|
|
|
|
which would generate a lot of configuration change events.
|
|
|
|
If Traefik took them all into account,
|
|
|
|
that would trigger a lot more configuration reloads than what is necessary,
|
|
|
|
or even useful.
|
|
|
|
|
|
|
|
In order to mitigate that, the `providers.providersThrottleDuration` option can be set.
|
|
|
|
It is the duration that Traefik waits for, after a configuration reload,
|
|
|
|
before taking into account any new configuration refresh event.
|
|
|
|
If any event arrives during that duration, only the most recent one is taken into account,
|
|
|
|
and all the previous others are dropped.
|
|
|
|
|
|
|
|
This option cannot be set per provider,
|
|
|
|
but the throttling algorithm applies independently to each of them.
|
|
|
|
It defaults to 2 seconds.
|
|
|
|
|
|
|
|
```toml tab="File (TOML)"
|
|
|
|
[providers]
|
|
|
|
providers.providersThrottleDuration = 10s
|
|
|
|
```
|
|
|
|
|
|
|
|
```yaml tab="File (YAML)"
|
|
|
|
providers:
|
|
|
|
providersThrottleDuration: 10s
|
|
|
|
```
|
|
|
|
|
|
|
|
```bash tab="CLI"
|
|
|
|
--providers.providersThrottleDuration=10s
|
|
|
|
```
|
|
|
|
|
2019-04-15 18:22:07 +02:00
|
|
|
<!--
|
2019-06-21 09:24:04 +02:00
|
|
|
TODO (document TCP VS HTTP dynamic configuration)
|
|
|
|
-->
|
|
|
|
|
|
|
|
## Restrict the Scope of Service Discovery
|
|
|
|
|
|
|
|
By default Traefik will create routes for all detected containers.
|
|
|
|
|
|
|
|
If you want to limit the scope of Traefik's service discovery,
|
|
|
|
i.e. disallow route creation for some containers,
|
|
|
|
you can do so in two different ways:
|
|
|
|
either with the generic configuration option `exposedByDefault`,
|
|
|
|
or with a finer granularity mechanism based on constraints.
|
|
|
|
|
|
|
|
### `exposedByDefault` and `traefik.enable`
|
|
|
|
|
|
|
|
List of providers that support that feature:
|
|
|
|
|
|
|
|
- [Docker](./docker.md#exposedbydefault)
|
2019-10-16 10:36:04 +02:00
|
|
|
- [Consul Catalog](./consul-catalog.md#exposedbydefault)
|
2019-06-21 09:24:04 +02:00
|
|
|
- [Rancher](./rancher.md#exposedbydefault)
|
|
|
|
- [Marathon](./marathon.md#exposedbydefault)
|
|
|
|
|
|
|
|
### Constraints
|
|
|
|
|
|
|
|
List of providers that support constraints:
|
|
|
|
|
|
|
|
- [Docker](./docker.md#constraints)
|
2019-10-16 10:36:04 +02:00
|
|
|
- [Consul Catalog](./consul-catalog.md#constraints)
|
2019-06-21 09:24:04 +02:00
|
|
|
- [Rancher](./rancher.md#constraints)
|
|
|
|
- [Marathon](./marathon.md#constraints)
|
|
|
|
- [Kubernetes CRD](./kubernetes-crd.md#labelselector)
|
2019-09-23 14:32:04 +02:00
|
|
|
- [Kubernetes Ingress](./kubernetes-ingress.md#labelselector)
|