2022-04-15 15:44:08 +02:00
---
title: "Traefik File Documentation"
description: "The file provider in Traefik Proxy lets you define the dynamic configuration in a YAML or TOML file. Read the technical documentation."
---
2019-03-14 16:46:05 +01:00
# Traefik & File
2019-02-26 05:50:07 -08:00
Good Old Configuration File
2021-02-11 19:04:03 +01:00
{: .subtitle }
2019-02-26 05:50:07 -08:00
2021-06-19 00:08:08 +02:00
The file provider lets you define the [dynamic configuration ](./overview.md ) in a YAML or TOML file.
2019-02-26 05:50:07 -08:00
2021-02-19 19:48:03 +02:00
It supports providing configuration through a [single configuration file ](#filename ) or [multiple separate files ](#directory ).
2019-02-26 05:50:07 -08:00
2019-09-23 14:32:04 +02:00
!!! info
2021-02-11 19:04:03 +01:00
The file provider is the default format used throughout the documentation to show samples of the configuration for many features.
2019-02-26 05:50:07 -08:00
2019-03-14 16:46:05 +01:00
!!! tip
2021-02-11 19:04:03 +01:00
The file provider can be a good solution for reusing common elements from other providers (e.g. declaring whitelist middlewares, basic authentication, ...)
2019-02-26 05:50:07 -08:00
2019-03-14 16:46:05 +01:00
## Configuration Examples
2019-02-26 05:50:07 -08:00
2019-03-14 16:46:05 +01:00
??? example "Declaring Routers, Middlewares & Services"
2019-02-26 05:50:07 -08:00
2019-06-26 18:18:04 +02:00
Enabling the file provider:
2021-02-11 19:04:03 +01:00
2019-07-15 10:22:03 +02:00
```yaml tab="File (YAML)"
2019-06-26 18:18:04 +02:00
providers:
2019-07-15 10:22:03 +02:00
file:
2019-12-09 11:48:05 +01:00
directory: "/path/to/dynamic/conf"
2019-07-15 10:22:03 +02:00
```
2021-02-11 19:04:03 +01:00
2021-06-19 00:08:08 +02:00
```toml tab="File (TOML)"
[providers.file]
directory = "/path/to/dynamic/conf"
```
2019-07-15 10:22:03 +02:00
```bash tab="CLI"
2019-12-09 11:48:05 +01:00
--providers.file.directory=/path/to/dynamic/conf
2019-06-26 18:18:04 +02:00
```
2021-02-11 19:04:03 +01:00
2019-06-26 18:18:04 +02:00
Declaring Routers, Middlewares & Services:
2021-02-11 19:04:03 +01:00
2019-06-26 18:18:04 +02:00
```yaml tab="YAML"
http:
2019-07-01 11:30:05 +02:00
# Add the router
2019-06-26 18:18:04 +02:00
routers:
router0:
2019-07-01 11:30:05 +02:00
entryPoints:
2019-06-26 18:18:04 +02:00
- web
middlewares:
- my-basic-auth
service: service-foo
2019-09-03 18:02:05 +02:00
rule: Path(`/foo` )
2021-02-11 19:04:03 +01:00
2019-07-01 11:30:05 +02:00
# Add the middleware
2019-06-26 18:18:04 +02:00
middlewares:
my-basic-auth:
basicAuth:
users:
- test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/
- test2:$apr1$d9hr9HBB$4HxwgUir3HP4EsggP/QNo0
2019-07-01 11:30:05 +02:00
usersFile: etc/traefik/.htpasswd
2021-02-11 19:04:03 +01:00
2019-07-01 11:30:05 +02:00
# Add the service
2019-06-26 18:18:04 +02:00
services:
service-foo:
2019-07-01 11:30:05 +02:00
loadBalancer:
2019-06-26 18:18:04 +02:00
servers:
- url: http://foo/
- url: http://bar/
2019-07-01 11:30:05 +02:00
passHostHeader: false
2019-06-26 18:18:04 +02:00
```
2019-02-26 05:50:07 -08:00
2021-06-19 00:08:08 +02:00
```toml tab="TOML"
[http]
# Add the router
[http.routers]
[http.routers.router0]
entryPoints = ["web"]
middlewares = ["my-basic-auth"]
service = "service-foo"
rule = "Path(`/foo` )"
# Add the middleware
[http.middlewares]
[http.middlewares.my-basic-auth.basicAuth]
users = ["test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/",
"test2:$apr1$d9hr9HBB$4HxwgUir3HP4EsggP/QNo0"]
usersFile = "etc/traefik/.htpasswd"
# Add the service
[http.services]
[http.services.service-foo]
[http.services.service-foo.loadBalancer]
[[http.services.service-foo.loadBalancer.servers]]
url = "http://foo/"
[[http.services.service-foo.loadBalancer.servers]]
url = "http://bar/"
```
2019-09-23 14:32:04 +02:00
## Provider Configuration
2019-02-26 05:50:07 -08:00
2021-02-11 19:04:03 +01:00
For an overview of all the options that can be set with the file provider, see the [dynamic configuration ](../reference/dynamic-configuration/file.md ) and [static configuration ](../reference/static-configuration/overview.md ) references.
2019-04-24 17:44:04 +02:00
2019-12-09 11:48:05 +01:00
!!! warning "Limitations"
With the file provider, Traefik listens for file system notifications to update the dynamic configuration.
2021-02-11 19:04:03 +01:00
2019-12-09 11:48:05 +01:00
If you use a mounted/bound file system in your orchestrator (like docker or kubernetes), the way the files are linked may be a source of errors.
2021-06-19 00:08:08 +02:00
If the link between the file systems is broken, when a source file/directory is changed/renamed, nothing will be reported to the linked file/directory, so the file system notifications will be neither triggered nor caught.
2021-02-11 19:04:03 +01:00
For example, in Docker, if the host file is renamed, the link to the mounted file is broken and the container's file is no longer updated.
To avoid this kind of issue, it is recommended to:
2019-12-09 11:48:05 +01:00
* set the Traefik [**directory** ](#directory ) configuration with the parent directory
* mount/bind the parent directory
2021-02-11 19:04:03 +01:00
As it is very difficult to listen to all file system notifications, Traefik uses [fsnotify ](https://github.com/fsnotify/fsnotify ).
2019-12-09 11:48:05 +01:00
If using a directory with a mounted directory does not fix your issue, please check your file system compatibility with fsnotify.
2021-02-11 19:04:03 +01:00
2019-09-23 14:32:04 +02:00
### `filename`
2019-02-26 05:50:07 -08:00
2020-02-18 17:30:05 +01:00
Defines the path to the configuration file.
!!! warning ""
2021-02-11 19:04:03 +01:00
The `filename` and `directory` options are mutually exclusive.
It is recommended to use `directory` .
2019-03-14 16:46:05 +01:00
2019-07-15 10:22:03 +02:00
```yaml tab="File (YAML)"
2019-06-26 18:18:04 +02:00
providers:
file:
2020-02-18 17:30:05 +01:00
filename: /path/to/config/dynamic_conf.yml
2019-07-15 10:22:03 +02:00
```
2021-06-19 00:08:08 +02:00
```toml tab="File (TOML)"
[providers]
[providers.file]
filename = "/path/to/config/dynamic_conf.toml"
```
2019-07-15 10:22:03 +02:00
```bash tab="CLI"
2021-06-19 00:08:08 +02:00
--providers.file.filename=/path/to/config/dynamic_conf.yml
2019-06-26 18:18:04 +02:00
```
2019-04-24 17:44:04 +02:00
### `directory`
2020-02-18 17:30:05 +01:00
Defines the path to the directory that contains the configuration files.
!!! warning ""
2021-02-11 19:04:03 +01:00
The `filename` and `directory` options are mutually exclusive.
It is recommended to use `directory` .
2019-03-14 16:46:05 +01:00
2019-07-15 10:22:03 +02:00
```yaml tab="File (YAML)"
2019-06-26 18:18:04 +02:00
providers:
file:
directory: /path/to/config
```
2021-06-19 00:08:08 +02:00
```toml tab="File (TOML)"
[providers]
[providers.file]
directory = "/path/to/config"
```
2019-07-15 10:22:03 +02:00
```bash tab="CLI"
--providers.file.directory=/path/to/config
```
2019-04-24 17:44:04 +02:00
### `watch`
2021-02-11 19:04:03 +01:00
Set the `watch` option to `true` to allow Traefik to automatically watch for file changes.
2019-03-14 16:46:05 +01:00
It works with both the `filename` and the `directory` options.
2019-07-15 10:22:03 +02:00
```yaml tab="File (YAML)"
2019-06-26 18:18:04 +02:00
providers:
file:
2019-12-09 11:48:05 +01:00
directory: /path/to/dynamic/conf
2019-06-26 18:18:04 +02:00
watch: true
```
2021-06-19 00:08:08 +02:00
```toml tab="File (TOML)"
[providers]
[providers.file]
directory = "/path/to/dynamic/conf"
watch = true
```
2019-07-15 10:22:03 +02:00
```bash tab="CLI"
2019-12-09 11:48:05 +01:00
--providers.file.directory=/my/path/to/dynamic/conf
2019-07-15 10:22:03 +02:00
--providers.file.watch=true
```
2019-06-26 18:18:04 +02:00
### Go Templating
2019-03-14 16:46:05 +01:00
!!! warning
2021-02-11 19:04:03 +01:00
2020-07-01 03:00:03 -07:00
Go Templating only works with dedicated dynamic configuration files.
2019-09-23 14:32:04 +02:00
Templating does not work in the Traefik main static configuration file.
2019-03-14 16:46:05 +01:00
2021-02-11 19:04:03 +01:00
Traefik supports using Go templating to automatically generate repetitive sections of configuration files.
2021-09-10 11:42:07 +02:00
These sections must be a valid [Go template ](https://pkg.go.dev/text/template/ ), and can use
2021-08-31 18:54:06 +02:00
[sprig template functions ](https://masterminds.github.io/sprig/ ).
2020-02-28 14:52:05 +01:00
2021-02-11 19:04:03 +01:00
To illustrate, it is possible to easily define multiple routers, services, and TLS certificates as described in the following examples:
2019-03-14 16:46:05 +01:00
??? example "Configuring Using Templating"
2021-02-11 19:04:03 +01:00
2021-06-19 00:08:08 +02:00
```yaml tab="YAML"
http:
routers:
{{range $i, $e := until 100 }}
router{{ $e }}-{{ env "MY_ENV_VAR" }}:
# ...
{{end}}
services:
{{range $i, $e := until 100 }}
application{{ $e }}:
# ...
{{end}}
tcp:
routers:
{{range $i, $e := until 100 }}
router{{ $e }}:
# ...
{{end}}
services:
{{range $i, $e := until 100 }}
service{{ $e }}:
# ...
{{end}}
tls:
certificates:
{{ range $i, $e := until 10 }}
- certFile: "/etc/traefik/cert-{{ $e }}.pem"
keyFile: "/etc/traefik/cert-{{ $e }}.key"
store:
- "my-store-foo-{{ $e }}"
- "my-store-bar-{{ $e }}"
{{end}}
```
2019-06-26 18:18:04 +02:00
```toml tab="TOML"
2019-03-14 16:46:05 +01:00
# template-rules.toml
[http]
2021-02-11 19:04:03 +01:00
2019-03-14 16:46:05 +01:00
[http.routers]
{{ range $i, $e := until 100 }}
2020-02-28 14:52:05 +01:00
[http.routers.router{{ $e }}-{{ env "MY_ENV_VAR" }}]
2019-03-14 16:46:05 +01:00
# ...
2021-02-11 19:04:03 +01:00
{{ end }}
2019-07-01 11:30:05 +02:00
[http.services]
2019-03-14 16:46:05 +01:00
{{ range $i, $e := until 100 }}
[http.services.service{{ $e }}]
# ...
2021-02-11 19:04:03 +01:00
{{ end }}
2019-03-14 16:46:05 +01:00
[tcp]
2021-02-11 19:04:03 +01:00
2019-03-14 16:46:05 +01:00
[tcp.routers]
{{ range $i, $e := until 100 }}
[tcp.routers.router{{ $e }}]
# ...
2021-02-11 19:04:03 +01:00
{{ end }}
2019-07-01 11:30:05 +02:00
[tcp.services]
2019-03-14 16:46:05 +01:00
{{ range $i, $e := until 100 }}
[http.services.service{{ $e }}]
# ...
2021-02-11 19:04:03 +01:00
{{ end }}
2019-03-14 16:46:05 +01:00
{{ range $i, $e := until 10 }}
2019-06-27 23:58:03 +02:00
[[tls.certificates]]
2019-07-01 11:30:05 +02:00
certFile = "/etc/traefik/cert-{{ $e }}.pem"
keyFile = "/etc/traefik/cert-{{ $e }}.key"
2020-06-17 16:48:04 +02:00
stores = ["my-store-foo-{{ $e }}", "my-store-bar-{{ $e }}"]
2019-03-14 16:46:05 +01:00
{{ end }}
2021-02-11 19:04:03 +01:00
2019-06-27 23:58:03 +02:00
[tls.config]
2019-03-14 16:46:05 +01:00
{{ range $i, $e := until 10 }}
2019-06-27 23:58:03 +02:00
[tls.config.TLS{{ $e }}]
2019-03-14 16:46:05 +01:00
# ...
{{ end }}
```
2022-09-09 09:17:53 -06:00
{!traefik-for-business-applications.md!}