API
Traefik exposes a number of information through an API handler, such as the configuration of all routers, services, middlewares, etc.
As with all features of Traefik, this handler can be enabled with the static configuration.
Security
Enabling the API in production is not recommended, because it will expose all configuration elements,including sensitive data.
In production, it should be at least secured by authentication and authorizations.
A good sane default (non exhaustive) set of recommendationswould be to apply the following protection mechanisms:
- At the transport level:NOT publicly exposing the API's port,keeping it restricted to internal networks(as in the principle of least privilege, applied to networks).
Configuration
If you enable the API, a new special service
named [email protected]
is created and then can be reference in a router.
To enable the API handler:
[api]
api: {}
--api=true
And then you will able to reference it like this.
- "traefik.http.routers.api.rule=PathPrefix(`/api`) || PathPrefix(`/dashboard`)"
- "[email protected]"
- "traefik.http.routers.api.middlewares=auth"
- "traefik.http.middlewares.auth.basicauth.users=test:$$apr1$$H6uskkkW$$IgXLP6ewTrSuBkTrqE8wj/,test2:$$apr1$$d9hr9HBB$$4HxwgUir3HP4EsggP/QNo0"
"labels": {
"traefik.http.routers.api.rule": "PathPrefix(`/api`) || PathPrefix(`/dashboard`)"
"traefik.http.routers.api.service": "[email protected]"
"traefik.http.routers.api.middlewares": "auth"
"traefik.http.middlewares.auth.basicauth.users": "test:$$apr1$$H6uskkkW$$IgXLP6ewTrSuBkTrqE8wj/,test2:$$apr1$$d9hr9HBB$$4HxwgUir3HP4EsggP/QNo0"
}
# Declaring the user list
labels:
- "traefik.http.routers.api.rule=PathPrefix(`/api`) || PathPrefix(`/dashboard`)"
- "[email protected]"
- "traefik.http.routers.api.middlewares=auth"
- "traefik.http.middlewares.auth.basicauth.users=test:$$apr1$$H6uskkkW$$IgXLP6ewTrSuBkTrqE8wj/,test2:$$apr1$$d9hr9HBB$$4HxwgUir3HP4EsggP/QNo0"
[http.routers.my-api]
rule="PathPrefix(`/api`) || PathPrefix(`/dashboard`)"
service="[email protected]"
middlewares=["auth"]
[http.middlewares.auth.basicAuth]
users = [
"test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/",
"test2:$apr1$d9hr9HBB$4HxwgUir3HP4EsggP/QNo0",
]
http:
routers:
api:
rule: PathPrefix(`/api`) || PathPrefix(`/dashboard`)
service: [email protected]
middlewares:
- auth
middlewares:
auth:
basicAuth:
users:
- "test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/"
- "test2:$apr1$d9hr9HBB$4HxwgUir3HP4EsggP/QNo0"
insecure
Enable the API in insecure
mode, which means that the API will be available directly on the entryPoint named traefik
.
Note
If the entryPoint named traefik
is not configured, it will be automatically created on port 8080.
[api]
insecure = true
api:
insecure: true
--api.insecure=true
dashboard
Optional, Default=true
Enable the dashboard. More about the dashboard features here.
[api]
dashboard = true
api:
dashboard: true
--api.dashboard=true
debug
Optional, Default=false
Enable additional endpoints for debugging and profiling, served under /debug/
.
[api]
debug = true
api:
debug: true
--api.debug=true
Endpoints
All the following endpoints must be accessed with a GET
HTTP request.
Path | Description |
---|---|
/api/http/routers | Lists all the HTTP routers information. |
/api/http/routers/{name} | Returns the information of the HTTP router specified by name . |
/api/http/services | Lists all the HTTP services information. |
/api/http/services/{name} | Returns the information of the HTTP service specified by name . |
/api/http/middlewares | Lists all the HTTP middlewares information. |
/api/http/middlewares/{name} | Returns the information of the HTTP middleware specified by name . |
/api/tcp/routers | Lists all the TCP routers information. |
/api/tcp/routers/{name} | Returns the information of the TCP router specified by name . |
/api/tcp/services | Lists all the TCP services information. |
/api/tcp/services/{name} | Returns the information of the TCP service specified by name . |
/api/entrypoints | Lists all the entry points information. |
/api/entrypoints/{name} | Returns the information of the entry point specified by name . |
/api/version | Returns information about Traefik version. |
/debug/vars | See the expvar Go documentation. |
/debug/pprof/ | See the pprof Index Go documentation. |
/debug/pprof/cmdline | See the pprof Cmdline Go documentation. |
/debug/pprof/profile | See the pprof Profile Go documentation. |
/debug/pprof/symbol | See the pprof Symbol Go documentation. |
/debug/pprof/trace | See the pprof Trace Go documentation. |