CLI & Ping

Checking the Health of your Traefik Instances

CLI

The CLI can be used to make a request to the /ping endpoint to check the health of Traefik. Its exit status is 0 if Traefik is healthy and 1 otherwise.

This can be used with HEALTHCHECK instruction or any other health check orchestration mechanism.

Usage

  1. traefik healthcheck [command] [flags] [arguments]

Example:

  1. $ traefik healthcheck
  2. OK: http://:8082/ping

Ping

The /ping health-check URL is enabled with the command-line --ping or config file option [ping].

The entryPoint where the /ping is active can be customized with the entryPoint option, whose default value is traefik (port 8080).

PathMethodDescription
/pingGET, HEADAn endpoint to check for Traefik process liveness. Return a code 200 with the content: OK

Configuration Example

To enable the API handler:

File (YAML)

  1. ping: {}

File (TOML)

  1. [ping]

CLI

  1. --ping=true

Configuration Options

FieldDescriptionDefaultRequired
ping.entryPointEnables /ping on a dedicated EntryPoint.traefikNo
ping.manualRoutingDisables the default internal router in order to allow one to create a custom router for the ping@internal service when set to true.falseNo
ping.terminatingStatusCodeDefines the status code for the ping handler during a graceful shut down. See more information here503No

terminatingStatusCode

During the period in which Traefik is gracefully shutting down, the ping handler returns a 503 status code by default.
If Traefik is behind, for example a load-balancer doing health checks (such as the Kubernetes LivenessProbe), another code might be expected as the signal for graceful termination.
In that case, the terminatingStatusCode can be used to set the code returned by the ping handler during termination.

File (YAML)

  1. ping:
  2. terminatingStatusCode: 204

File (TOML)

  1. [ping]
  2. terminatingStatusCode = 204

CLI

  1. --ping.terminatingStatusCode=204