2022-04-15 15:44:08 +02:00
---
title: "Traefik Configuration Discovery Overview"
description: "Configuration discovery in Traefik is achieved through Providers. The providers are infrastructure components. Read the documentation to learn more."
---
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_ .
2021-02-11 19:04:03 +01:00
The _providers_ are infrastructure components, whether orchestrators, container engines, cloud providers, or key-value stores.
The idea is that Traefik queries the provider APIs in order to find relevant information about routing,
and when Traefik detects a change, it dynamically updates the routes.
2019-02-26 05:50:07 -08:00
## Orchestrators
2021-02-11 19:04:03 +01:00
While each provider is different, you can think of each as belonging to one of four categories:
2019-02-26 05:50:07 -08:00
2021-02-11 19:04:03 +01:00
- 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: uses files to define configuration
2019-02-26 05:50:07 -08:00
2020-10-16 01:54:04 +13:00
## Provider Namespace
2021-02-11 19:04:03 +01:00
When you declare certain objects in the Traefik dynamic configuration,
such as middleware, services, TLS options or server transports, they reside in their provider's namespace.
For example, if you declare a middleware using a Docker label, it resides in the Docker provider namespace.
2020-10-16 01:54:04 +13:00
2021-02-11 19:04:03 +01:00
If you use multiple providers and wish to reference such an object declared in another provider
(e.g. referencing a cross-provider object like middleware), then the object name should be suffixed by the `@`
separator, and the provider name.
2020-10-16 01:54:04 +13:00
2021-06-25 00:34:05 +08:00
For the list of the providers names, see the [supported providers ](#supported-providers ) table below.
2020-10-16 01:54:04 +13:00
```text
< resource-name > @< provider-name >
```
!!! important "Kubernetes Namespace"
As Kubernetes also has its own notion of namespace,
2021-02-11 19:04:03 +01:00
one should not confuse the _provider namespace_ with the _Kubernetes Namespace_ of a resource when in the context of 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.
On the other hand, if you were to declare a middleware as a Custom Resource in Kubernetes and use the non-CRD Ingress objects,
you would have to add the Kubernetes Namespace of the middleware to the annotation like this `<middleware-namespace>-<middleware-name>@kubernetescrd` .
2020-10-16 01:54:04 +13:00
2021-02-11 19:04:03 +01: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.
```yaml tab="File (YAML)"
http:
middlewares:
add-foo-prefix:
addPrefix:
prefix: "/foo"
```
2021-06-19 00:08:08 +02:00
```toml tab="File (TOML)"
[http.middlewares]
[http.middlewares.add-foo-prefix.addPrefix]
prefix = "/foo"
```
2020-10-16 01:54:04 +13:00
Using the add-foo-prefix middleware from other providers:
2023-05-10 15:28:05 +02:00
```yaml tab="Docker & Swarm"
2020-10-16 01:54:04 +13:00
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"
2023-03-20 15:38:08 +01:00
apiVersion: traefik.io/v1alpha1
2020-10-16 01:54:04 +13:00
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.
```
2021-02-11 19:04:03 +01:00
2020-10-16 01:54:04 +13:00
```yaml tab="Kubernetes Ingress"
2023-03-20 15:38:08 +01:00
apiVersion: traefik.io/v1alpha1
2020-10-16 01:54:04 +13:00
kind: Middleware
metadata:
name: stripprefix
namespace: appspace
spec:
stripPrefix:
prefixes:
- /stripit
2021-02-11 19:04:03 +01:00
2020-10-16 01:54:04 +13:00
---
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
```
2021-02-11 19:04:03 +01:00
## Supported Providers
2019-02-26 05:50:07 -08:00
2021-02-11 19:04:03 +01:00
Below is the list of the currently supported providers in Traefik.
2019-02-26 05:50:07 -08:00
2021-06-25 00:34:05 +08:00
| Provider | Type | Configuration Type | Provider Name |
|---------------------------------------------------|--------------|----------------------|---------------------|
| [Docker ](./docker.md ) | Orchestrator | Label | `docker` |
| [Kubernetes IngressRoute ](./kubernetes-crd.md ) | Orchestrator | Custom Resource | `kubernetescrd` |
| [Kubernetes Ingress ](./kubernetes-ingress.md ) | Orchestrator | Ingress | `kubernetes` |
| [Kubernetes Gateway API ](./kubernetes-gateway.md ) | Orchestrator | Gateway API Resource | `kubernetesgateway` |
| [Consul Catalog ](./consul-catalog.md ) | Orchestrator | Label | `consulcatalog` |
2022-06-10 11:32:08 -05:00
| [Nomad ](./nomad.md ) | Orchestrator | Label | `nomad` |
2021-06-25 00:34:05 +08:00
| [ECS ](./ecs.md ) | Orchestrator | Label | `ecs` |
| [File ](./file.md ) | Manual | YAML/TOML format | `file` |
| [Consul ](./consul.md ) | KV | KV | `consul` |
| [Etcd ](./etcd.md ) | KV | KV | `etcd` |
| [ZooKeeper ](./zookeeper.md ) | KV | KV | `zookeeper` |
| [Redis ](./redis.md ) | KV | KV | `redis` |
| [HTTP ](./http.md ) | Manual | JSON format | `http` |
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
2021-02-11 19:04:03 +01:00
The current version of Traefik does not yet support every provider that Traefik v1.7 did.
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
2021-02-11 19:04:03 +01:00
### Configuration Reload Frequency
#### `providers.providersThrottleDuration`
_Optional, Default: 2s_
2019-09-30 18:24:05 +02:00
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,
2021-02-11 19:04:03 +01:00
that would trigger a lot more configuration reloads than is necessary,
2019-09-30 18:24:05 +02:00
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.
2021-02-11 19:04:03 +01:00
If multiple events occur within this time, only the most recent one is taken into account,
and all others are discarded.
2019-09-30 18:24:05 +02:00
This option cannot be set per provider,
2021-02-11 19:04:03 +01:00
but the throttling algorithm applies to each of them independently.
The value of `providers.providersThrottleDuration` should be provided in seconds or as a valid duration format,
see [time.ParseDuration ](https://golang.org/pkg/time/#ParseDuration ).
2019-09-30 18:24:05 +02:00
```yaml tab="File (YAML)"
providers:
providersThrottleDuration: 10s
```
2021-06-19 00:08:08 +02:00
```toml tab="File (TOML)"
[providers]
providers.providersThrottleDuration = 10s
```
2019-09-30 18:24:05 +02:00
```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
2021-02-11 19:04:03 +01:00
By default, Traefik creates routes for all detected containers.
2019-06-21 09:24:04 +02:00
2021-02-11 19:04:03 +01:00
If you want to limit the scope of the Traefik service discovery,
2019-06-21 09:24:04 +02:00
i.e. disallow route creation for some containers,
you can do so in two different ways:
2021-02-11 19:04:03 +01:00
- the generic configuration option `exposedByDefault` ,
- a finer granularity mechanism based on constraints.
2019-06-21 09:24:04 +02:00
### `exposedByDefault` and `traefik.enable`
2021-02-11 19:04:03 +01:00
List of providers that support these features:
2019-06-21 09:24:04 +02:00
- [Docker ](./docker.md#exposedbydefault )
2022-09-20 12:22:08 +02:00
- [ECS ](./ecs.md#exposedbydefault )
2019-10-16 10:36:04 +02:00
- [Consul Catalog ](./consul-catalog.md#exposedbydefault )
2022-06-10 11:32:08 -05:00
- [Nomad ](./nomad.md#exposedbydefault )
2019-06-21 09:24:04 +02:00
### Constraints
List of providers that support constraints:
- [Docker ](./docker.md#constraints )
2022-09-20 12:22:08 +02:00
- [ECS ](./ecs.md#constraints )
2019-10-16 10:36:04 +02:00
- [Consul Catalog ](./consul-catalog.md#constraints )
2022-06-10 11:32:08 -05:00
- [Nomad ](./nomad.md#constraints )
2019-06-21 09:24:04 +02:00
- [Kubernetes CRD ](./kubernetes-crd.md#labelselector )
2019-09-23 14:32:04 +02:00
- [Kubernetes Ingress ](./kubernetes-ingress.md#labelselector )
2021-02-11 19:04:03 +01:00
- [Kubernetes Gateway ](./kubernetes-gateway.md#labelselector )
2022-09-09 09:17:53 -06:00
{!traefik-for-business-applications.md!}