2022-04-15 15:44:08 +02:00
---
title: "Traefik Metrics Overview"
2022-12-19 14:32:04 +01:00
description: "Traefik Proxy supports these metrics backend systems: Datadog, InfluxDB 2.X, Prometheus, and StatsD. Read the full documentation to get started."
2022-04-15 15:44:08 +02:00
---
2019-07-18 21:36:05 +02:00
# Metrics
2022-09-23 06:06:09 -03:00
Traefik supports these metrics backends:
2019-07-18 21:36:05 +02:00
2019-09-02 12:18:04 +02:00
- [Datadog ](./datadog.md )
2022-02-09 17:32:12 +03:00
- [InfluxDB2 ](./influxdb2.md )
2019-07-18 21:36:05 +02:00
- [Prometheus ](./prometheus.md )
- [StatsD ](./statsd.md )
2024-03-12 09:48:04 +01:00
Traefik Proxy hosts an official Grafana dashboard for both [on-premises ](https://grafana.com/grafana/dashboards/17346 )
and [Kubernetes ](https://grafana.com/grafana/dashboards/17347 ) deployments.
2022-11-08 15:32:06 +01:00
2024-01-30 16:28:05 +01:00
## Common Options
### `addInternals`
_Optional, Default="false"_
2024-04-04 10:14:06 +02:00
Enables metrics for internal resources (e.g.: `ping@internals` ).
2024-01-30 16:28:05 +01:00
```yaml tab="File (YAML)"
metrics:
addInternals: true
```
```toml tab="File (TOML)"
[metrics]
2024-03-12 09:48:04 +01:00
addInternals = true
2024-01-30 16:28:05 +01:00
```
```bash tab="CLI"
--metrics.addinternals
```
2022-02-03 15:16:12 +01:00
## Global Metrics
2021-03-25 16:52:04 +01:00
2023-03-20 16:02:06 +01:00
| Metric | Type | [Labels ](#labels ) | Description |
|----------------------------|-------|--------------------------|--------------------------------------------------------------------|
| Config reload total | Count | | The total count of configuration reloads. |
| Config reload last success | Gauge | | The timestamp of the last configuration reload success. |
| Open connections | Gauge | `entrypoint` , `protocol` | The current count of open connections, by entrypoint and protocol. |
| TLS certificates not after | Gauge | | The expiration date of certificates. |
2021-03-25 16:52:04 +01:00
```prom tab="Prometheus"
traefik_config_reloads_total
traefik_config_last_reload_success
2023-03-20 16:02:06 +01:00
traefik_open_connections
2022-09-23 06:06:09 -03:00
traefik_tls_certs_not_after
2021-03-25 16:52:04 +01:00
```
```dd tab="Datadog"
2022-09-23 06:06:09 -03:00
config.reload.total
config.reload.lastSuccessTimestamp
2023-03-20 16:02:06 +01:00
open.connections
2022-02-03 15:16:12 +01:00
tls.certs.notAfterTimestamp
2021-03-25 16:52:04 +01:00
```
2022-12-19 14:32:04 +01:00
```influxdb tab="InfluxDB2"
2022-09-23 06:06:09 -03:00
traefik.config.reload.total
traefik.config.reload.lastSuccessTimestamp
2023-03-20 16:02:06 +01:00
traefik.open.connections
2022-02-03 15:16:12 +01:00
traefik.tls.certs.notAfterTimestamp
2021-03-25 16:52:04 +01:00
```
```statsd tab="StatsD"
# Default prefix: "traefik"
2022-09-23 06:06:09 -03:00
{prefix}.config.reload.total
{prefix}.config.reload.lastSuccessTimestamp
2023-03-20 16:02:06 +01:00
{prefix}.open.connections
2022-02-03 15:16:12 +01:00
{prefix}.tls.certs.notAfterTimestamp
2021-03-25 16:52:04 +01:00
```
2023-01-10 17:06:04 +01:00
```opentelemetry tab="OpenTelemetry"
traefik_config_reloads_total
traefik_config_last_reload_success
2023-03-20 16:02:06 +01:00
traefik_open_connections
2023-01-10 17:06:04 +01:00
traefik_tls_certs_not_after
```
2023-03-20 16:02:06 +01:00
### Labels
Here is a comprehensive list of labels that are provided by the global metrics:
2024-03-12 09:48:04 +01:00
| Label | Description | example |
|--------------|----------------------------------------|----------------------|
| `entrypoint` | Entrypoint that handled the connection | "example_entrypoint" |
| `protocol` | Connection protocol | "TCP" |
2023-03-20 16:02:06 +01:00
## HTTP Metrics
### EntryPoint Metrics
2021-03-25 16:52:04 +01:00
2022-09-23 06:06:09 -03:00
| Metric | Type | [Labels ](#labels ) | Description |
|-----------------------|-----------|--------------------------------------------|---------------------------------------------------------------------|
| Requests total | Count | `code` , `method` , `protocol` , `entrypoint` | The total count of HTTP requests received by an entrypoint. |
| Requests TLS total | Count | `tls_version` , `tls_cipher` , `entrypoint` | The total count of HTTPS requests received by an entrypoint. |
| Request duration | Histogram | `code` , `method` , `protocol` , `entrypoint` | Request processing duration histogram on an entrypoint. |
| Requests bytes total | Count | `code` , `method` , `protocol` , `entrypoint` | The total size of HTTP requests in bytes handled by an entrypoint. |
| Responses bytes total | Count | `code` , `method` , `protocol` , `entrypoint` | The total size of HTTP responses in bytes handled by an entrypoint. |
2021-03-25 16:52:04 +01:00
```prom tab="Prometheus"
traefik_entrypoint_requests_total
traefik_entrypoint_requests_tls_total
traefik_entrypoint_request_duration_seconds
2022-09-12 17:10:09 +02:00
traefik_entrypoint_requests_bytes_total
2022-09-23 06:06:09 -03:00
traefik_entrypoint_responses_bytes_total
2022-09-12 17:10:09 +02:00
```
```dd tab="Datadog"
2022-09-23 06:06:09 -03:00
entrypoint.request.total
entrypoint.request.tls.total
entrypoint.request.duration
entrypoint.requests.bytes.total
2022-09-12 17:10:09 +02:00
entrypoint.responses.bytes.total
```
2022-12-19 14:32:04 +01:00
```influxdb tab="InfluxDB2"
2022-09-23 06:06:09 -03:00
traefik.entrypoint.requests.total
traefik.entrypoint.requests.tls.total
traefik.entrypoint.request.duration
traefik.entrypoint.requests.bytes.total
2022-09-12 17:10:09 +02:00
traefik.entrypoint.responses.bytes.total
```
```statsd tab="StatsD"
# Default prefix: "traefik"
2022-09-23 06:06:09 -03:00
{prefix}.entrypoint.request.total
{prefix}.entrypoint.request.tls.total
{prefix}.entrypoint.request.duration
{prefix}.entrypoint.requests.bytes.total
2022-09-12 17:10:09 +02:00
{prefix}.entrypoint.responses.bytes.total
```
2023-01-10 17:06:04 +01:00
```opentelemetry tab="OpenTelemetry"
traefik_entrypoint_requests_total
traefik_entrypoint_requests_tls_total
traefik_entrypoint_request_duration_seconds
traefik_entrypoint_requests_bytes_total
traefik_entrypoint_responses_bytes_total
```
2023-03-20 16:02:06 +01:00
### Router Metrics
2021-03-25 16:52:04 +01:00
2022-09-23 06:06:09 -03:00
| Metric | Type | [Labels ](#labels ) | Description |
|-----------------------|-----------|---------------------------------------------------|----------------------------------------------------------------|
| Requests total | Count | `code` , `method` , `protocol` , `router` , `service` | The total count of HTTP requests handled by a router. |
| Requests TLS total | Count | `tls_version` , `tls_cipher` , `router` , `service` | The total count of HTTPS requests handled by a router. |
| Request duration | Histogram | `code` , `method` , `protocol` , `router` , `service` | Request processing duration histogram on a router. |
| Requests bytes total | Count | `code` , `method` , `protocol` , `router` , `service` | The total size of HTTP requests in bytes handled by a router. |
| Responses bytes total | Count | `code` , `method` , `protocol` , `router` , `service` | The total size of HTTP responses in bytes handled by a router. |
2022-02-03 15:16:12 +01:00
```prom tab="Prometheus"
traefik_router_requests_total
traefik_router_requests_tls_total
traefik_router_request_duration_seconds
2022-09-12 17:10:09 +02:00
traefik_router_requests_bytes_total
2022-09-23 06:06:09 -03:00
traefik_router_responses_bytes_total
2022-09-12 17:10:09 +02:00
```
```dd tab="Datadog"
2022-09-23 06:06:09 -03:00
router.request.total
router.request.tls.total
router.request.duration
router.requests.bytes.total
2022-09-12 17:10:09 +02:00
router.responses.bytes.total
```
2022-12-19 14:32:04 +01:00
```influxdb tab="InfluxDB2"
2022-09-23 06:06:09 -03:00
traefik.router.requests.total
traefik.router.requests.tls.total
traefik.router.request.duration
traefik.router.requests.bytes.total
2022-09-12 17:10:09 +02:00
traefik.router.responses.bytes.total
```
```statsd tab="StatsD"
# Default prefix: "traefik"
2022-09-23 06:06:09 -03:00
{prefix}.router.request.total
{prefix}.router.request.tls.total
{prefix}.router.request.duration
{prefix}.router.requests.bytes.total
2022-09-12 17:10:09 +02:00
{prefix}.router.responses.bytes.total
```
2023-01-10 17:06:04 +01:00
```opentelemetry tab="OpenTelemetry"
traefik_router_requests_total
traefik_router_requests_tls_total
traefik_router_request_duration_seconds
traefik_router_requests_bytes_total
traefik_router_responses_bytes_total
```
2023-03-20 16:02:06 +01:00
### Service Metrics
2022-02-03 15:16:12 +01:00
2022-09-23 06:06:09 -03:00
| Metric | Type | Labels | Description |
|-----------------------|-----------|-----------------------------------------|-------------------------------------------------------------|
| Requests total | Count | `code` , `method` , `protocol` , `service` | The total count of HTTP requests processed on a service. |
| Requests TLS total | Count | `tls_version` , `tls_cipher` , `service` | The total count of HTTPS requests processed on a service. |
| Request duration | Histogram | `code` , `method` , `protocol` , `service` | Request processing duration histogram on a service. |
| Retries total | Count | `service` | The count of requests retries on a service. |
| Server UP | Gauge | `service` , `url` | Current service's server status, 0 for a down or 1 for up. |
| Requests bytes total | Count | `code` , `method` , `protocol` , `service` | The total size of requests in bytes received by a service. |
| Responses bytes total | Count | `code` , `method` , `protocol` , `service` | The total size of responses in bytes returned by a service. |
2021-03-25 16:52:04 +01:00
```prom tab="Prometheus"
traefik_service_requests_total
traefik_service_requests_tls_total
traefik_service_request_duration_seconds
traefik_service_retries_total
traefik_service_server_up
2022-09-12 17:10:09 +02:00
traefik_service_requests_bytes_total
2022-09-23 06:06:09 -03:00
traefik_service_responses_bytes_total
2022-09-12 17:10:09 +02:00
```
```dd tab="Datadog"
2022-09-23 06:06:09 -03:00
service.request.total
router.service.tls.total
service.request.duration
service.retries.total
service.server.up
service.requests.bytes.total
2022-09-12 17:10:09 +02:00
service.responses.bytes.total
```
2022-12-19 14:32:04 +01:00
```influxdb tab="InfluxDB2"
2022-09-23 06:06:09 -03:00
traefik.service.requests.total
traefik.service.requests.tls.total
traefik.service.request.duration
traefik.service.retries.total
traefik.service.server.up
traefik.service.requests.bytes.total
2022-09-12 17:10:09 +02:00
traefik.service.responses.bytes.total
```
```statsd tab="StatsD"
# Default prefix: "traefik"
2022-09-23 06:06:09 -03:00
{prefix}.service.request.total
{prefix}.service.request.tls.total
{prefix}.service.request.duration
{prefix}.service.retries.total
{prefix}.service.server.up
{prefix}.service.requests.bytes.total
2022-09-12 17:10:09 +02:00
{prefix}.service.responses.bytes.total
```
2023-01-10 17:06:04 +01:00
```opentelemetry tab="OpenTelemetry"
traefik_service_requests_total
traefik_service_requests_tls_total
traefik_service_request_duration_seconds
traefik_service_retries_total
traefik_service_server_up
traefik_service_requests_bytes_total
traefik_service_responses_bytes_total
```
2023-03-20 16:02:06 +01:00
### Labels
2022-02-09 09:58:08 +01:00
Here is a comprehensive list of labels that are provided by the metrics:
| Label | Description | example |
|---------------|---------------------------------------|----------------------------|
| `cn` | Certificate Common Name | "example.com" |
| `code` | Request code | "200" |
| `entrypoint` | Entrypoint that handled the request | "example_entrypoint" |
| `method` | Request Method | "GET" |
| `protocol` | Request protocol | "http" |
| `router` | Router that handled the request | "example_router" |
| `sans` | Certificate Subject Alternative NameS | "example.com" |
| `serial` | Certificate Serial Number | "123..." |
| `service` | Service that handled the request | "example_service@provider " |
| `tls_cipher` | TLS cipher used for the request | "TLS_FALLBACK_SCSV" |
| `tls_version` | TLS version used for the request | "1.0" |
| `url` | Service server url | "http://example.com" |
!!! info "`method` label value"
If the HTTP method verb on a request is not one defined in the set of common methods for [`HTTP/1.1` ](https://developer.mozilla.org/en-US/docs/Web/HTTP/Methods )
or the [`PRI` ](https://datatracker.ietf.org/doc/html/rfc7540#section-11.6 ) verb (for `HTTP/2` ),
then the value for the method label becomes `EXTENSION_METHOD` .
2024-03-12 09:48:04 +01:00
## Semantic Conventions for HTTP Metrics
Traefik Proxy follows [official OTLP semantic conventions v1.23.1 ](https://github.com/open-telemetry/semantic-conventions/blob/v1.23.1/docs/http/http-metrics.md ).
### HTTP Server
| Metric | Type | [Labels ](#labels ) | Description |
|-------------------------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|
| http.server.request.duration | Histogram | `error.type` , `http.request.method` , `http.response.status_code` , `network.protocol.name` , `server.address` , `server.port` , `url.scheme` | Duration of HTTP server requests |
#### Labels
Here is a comprehensive list of labels that are provided by the metrics:
| Label | Description | example |
|-----------------------------|--------------------------------------------------------------|---------------|
| `error.type` | Describes a class of error the operation ended with | "500" |
| `http.request.method` | HTTP request method | "GET" |
| `http.response.status_code` | HTTP response status code | "200" |
| `network.protocol.name` | OSI application layer or non-OSI equivalent | "http/1.1" |
| `network.protocol.version` | Version of the protocol specified in `network.protocol.name` | "1.1" |
| `server.address` | Name of the local HTTP server that received the request | "example.com" |
| `server.port` | Port of the local HTTP server that received the request | "80" |
| `url.scheme` | The URI scheme component identifying the used protocol | "http" |
### HTTP Client
| Metric | Type | [Labels ](#labels ) | Description |
|-------------------------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|
| http.client.request.duration | Histogram | `error.type` , `http.request.method` , `http.response.status_code` , `network.protocol.name` , `server.address` , `server.port` , `url.scheme` | Duration of HTTP client requests |
#### Labels
Here is a comprehensive list of labels that are provided by the metrics:
| Label | Description | example |
|-----------------------------|--------------------------------------------------------------|---------------|
| `error.type` | Describes a class of error the operation ended with | "500" |
| `http.request.method` | HTTP request method | "GET" |
| `http.response.status_code` | HTTP response status code | "200" |
| `network.protocol.name` | OSI application layer or non-OSI equivalent | "http/1.1" |
| `network.protocol.version` | Version of the protocol specified in `network.protocol.name` | "1.1" |
| `server.address` | Name of the local HTTP server that received the request | "example.com" |
| `server.port` | Port of the local HTTP server that received the request | "80" |
| `url.scheme` | The URI scheme component identifying the used protocol | "http" |