2019-02-26 13:50:07 +00:00
|
|
|
# The Dashboard
|
|
|
|
|
|
|
|
See What's Going On
|
|
|
|
{: .subtitle }
|
|
|
|
|
2019-10-07 12:38:06 +00:00
|
|
|
The dashboard is the central place that shows you the current active routes handled by Traefik.
|
2019-02-26 13:50:07 +00:00
|
|
|
|
|
|
|
<figure>
|
2019-09-10 12:40:05 +00:00
|
|
|
<img src="../../assets/img/webui-dashboard.png" alt="Dashboard - Providers" />
|
|
|
|
<figcaption>The dashboard in action</figcaption>
|
2019-02-26 13:50:07 +00:00
|
|
|
</figure>
|
|
|
|
|
2019-10-07 12:38:06 +00:00
|
|
|
The dashboard is available at the same location as the [API](./api.md) but on the path `/dashboard/` by default.
|
2019-02-26 13:50:07 +00:00
|
|
|
|
2019-10-07 12:38:06 +00:00
|
|
|
!!! warning "The trailing slash `/` in `/dashboard/` is mandatory"
|
2019-02-26 13:50:07 +00:00
|
|
|
|
2019-10-07 12:38:06 +00:00
|
|
|
There are 2 ways to configure and access the dashboard:
|
|
|
|
|
|
|
|
- [Secure mode (Recommended)](#secure-mode)
|
|
|
|
- [Insecure mode](#insecure-mode)
|
|
|
|
|
|
|
|
!!! note ""
|
|
|
|
There is also a redirect of the path `/` to the path `/dashboard/`,
|
|
|
|
but one should not rely on that property as it is bound to change,
|
|
|
|
and it might make for confusing routing rules anyway.
|
|
|
|
|
|
|
|
## Secure Mode
|
|
|
|
|
|
|
|
This is the **recommended** method.
|
|
|
|
|
2019-10-25 15:32:04 +00:00
|
|
|
Start by enabling the dashboard by using the following option from [Traefik's API](./api.md)
|
|
|
|
on the [static configuration](../getting-started/configuration-overview.md#the-static-configuration):
|
2019-02-26 13:50:07 +00:00
|
|
|
|
2019-07-22 07:58:04 +00:00
|
|
|
```toml tab="File (TOML)"
|
|
|
|
[api]
|
|
|
|
# Dashboard
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
# Default: true
|
|
|
|
#
|
|
|
|
dashboard = true
|
|
|
|
```
|
2019-02-26 13:50:07 +00:00
|
|
|
|
2019-07-22 07:58:04 +00:00
|
|
|
```yaml tab="File (YAML)"
|
|
|
|
api:
|
|
|
|
# Dashboard
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
# Default: true
|
|
|
|
#
|
|
|
|
dashboard: true
|
|
|
|
```
|
2019-02-26 13:50:07 +00:00
|
|
|
|
2019-07-22 07:58:04 +00:00
|
|
|
```bash tab="CLI"
|
|
|
|
# Dashboard
|
|
|
|
#
|
|
|
|
# Optional
|
|
|
|
# Default: true
|
|
|
|
#
|
|
|
|
--api.dashboard=true
|
|
|
|
```
|
2019-02-26 13:50:07 +00:00
|
|
|
|
2019-11-12 14:40:05 +00:00
|
|
|
Then define a routing configuration on Traefik itself,
|
|
|
|
with a router attached to the service `api@internal` in the
|
2019-10-25 15:32:04 +00:00
|
|
|
[dynamic configuration](../getting-started/configuration-overview.md#the-dynamic-configuration),
|
|
|
|
to allow defining:
|
2019-10-07 12:38:06 +00:00
|
|
|
|
2019-10-25 15:32:04 +00:00
|
|
|
- One or more security features through [middlewares](../middlewares/overview.md)
|
2019-10-07 12:38:06 +00:00
|
|
|
like authentication ([basicAuth](../middlewares/basicauth.md) , [digestAuth](../middlewares/digestauth.md),
|
|
|
|
[forwardAuth](../middlewares/forwardauth.md)) or [whitelisting](../middlewares/ipwhitelist.md).
|
|
|
|
|
2019-10-25 15:32:04 +00:00
|
|
|
- A [router rule](#dashboard-router-rule) for accessing the dashboard,
|
2019-10-07 12:38:06 +00:00
|
|
|
through Traefik itself (sometimes referred as "Traefik-ception").
|
|
|
|
|
2019-10-25 15:32:04 +00:00
|
|
|
??? example "Dashboard Dynamic Configuration Examples"
|
2019-11-12 14:40:05 +00:00
|
|
|
--8<-- "content/operations/include-api-examples.md"
|
2019-10-25 15:32:04 +00:00
|
|
|
|
|
|
|
### Dashboard Router Rule
|
|
|
|
|
|
|
|
As underlined in the [documentation for the `api.dashboard` option](./api.md#dashboard),
|
|
|
|
the [router rule](../routing/routers/index.md#rule) defined for Traefik must match
|
|
|
|
the path prefixes `/api` and `/dashboard`.
|
|
|
|
|
|
|
|
We recommend to use a "Host Based rule" as ```Host(`traefik.domain.com`)``` to match everything on the host domain,
|
|
|
|
or to make sure that the defined rule captures both prefixes:
|
|
|
|
|
|
|
|
```bash tab="Host Rule"
|
2019-12-09 11:32:04 +00:00
|
|
|
# The dashboard can be accessed on http://traefik.domain.com/dashboard/
|
2019-10-25 15:32:04 +00:00
|
|
|
rule = "Host(`traefik.domain.com`)"
|
|
|
|
```
|
|
|
|
|
|
|
|
```bash tab="Path Prefix Rule"
|
2019-12-09 11:32:04 +00:00
|
|
|
# The dashboard can be accessed on http://domain.com/dashboard/ or http://traefik.domain.com/dashboard/
|
2019-10-25 15:32:04 +00:00
|
|
|
rule = "PathPrefix(`/api`) || PathPrefix(`/dashboard`)"
|
|
|
|
```
|
|
|
|
|
|
|
|
```bash tab="Combination of Rules"
|
2019-12-09 11:32:04 +00:00
|
|
|
# The dashboard can be accessed on http://traefik.domain.com/dashboard/
|
2019-10-25 15:32:04 +00:00
|
|
|
rule = "Host(`traefik.domain.com`) && (PathPrefix(`/api`) || PathPrefix(`/dashboard`))"
|
|
|
|
```
|
2019-10-07 12:38:06 +00:00
|
|
|
|
|
|
|
## Insecure Mode
|
|
|
|
|
|
|
|
This mode is not recommended because it does not allow the use of security features.
|
|
|
|
|
|
|
|
To enable the "insecure mode", use the following options from [Traefik's API](./api.md#insecure):
|
|
|
|
|
|
|
|
```toml tab="File (TOML)"
|
|
|
|
[api]
|
|
|
|
dashboard = true
|
|
|
|
insecure = true
|
|
|
|
```
|
|
|
|
|
|
|
|
```yaml tab="File (YAML)"
|
|
|
|
api:
|
|
|
|
dashboard: true
|
|
|
|
insecure: true
|
|
|
|
```
|
|
|
|
|
|
|
|
```bash tab="CLI"
|
|
|
|
--api.dashboard=true --api.insecure=true
|
|
|
|
```
|
2019-02-26 13:50:07 +00:00
|
|
|
|
2019-10-07 12:38:06 +00:00
|
|
|
You can now access the dashboard on the port `8080` of the Traefik instance,
|
|
|
|
at the following URL: `http://<Traefik IP>:8080/dashboard/` (trailing slash is mandatory).
|