SPIFFE

Secure the backend connection with SPIFFE.

SPIFFE (Secure Production Identity Framework For Everyone), provides a secure identity in the form of a specially crafted X.509 certificate, to every workload in an environment.

Traefik is able to connect to the Workload API to obtain an X509-SVID used to secure the connection with SPIFFE enabled backends.

SPIFFE can cause Traefik to stall

When using SPIFFE, Traefik will wait for the first SVID to be delivered before starting. If Traefik is hanging when waiting on SPIFFE SVID delivery, please double check that it is correctly registered as workload in your SPIFFE infrastructure.

Workload API

To enable SPIFFE globally, you need to set up the static configuration. The workloadAPIAddr option specifies the address of the SPIFFE Workload API.

File (YAML)

  1. ## Static configuration.
  2. spiffe:
  3. workloadAPIAddr: localhost

File (TOML)

  1. ## Static configuration
  2. [spiffe]
  3. workloadAPIAddr: localhost

CLI

  1. ## Static configuration.
  2. --spiffe.workloadAPIAddr=localhost

ServersTransport

Enabling SPIFFE does not imply that backend connections are going to use it automatically. Each ServersTransport or TCPServersTransport, that is meant to be secured with SPIFFE, must explicitly enable it (see SPIFFE with ServersTransport or SPIFFE with TCPServersTransport).

Configuration Example

File (YAML)

  1. serversTransport:
  2. spiffe:
  3. ids:
  4. - spiffe://trust-domain/id1
  5. - spiffe://trust-domain/id2
  6. trustDomain: "spiffe://trust-domain"

File (TOML)

  1. [serversTransport.spiffe]
  2. ids = [ "spiffe://trust-domain/id1", "spiffe://trust-domain/id2" ]
  3. trustDomain = "spiffe://trust-domain"

Kubernetes

  1. apiVersion: traefik.io/v1alpha1
  2. kind: ServersTransportTCP
  3. metadata:
  4. name: mytransport
  5. namespace: default
  6. spec:
  7. spiffe:
  8. ids:
  9. - spiffe://trust-domain/id1
  10. - spiffe://trust-domain/id2