2020-01-14 15:48:06 +01:00
# Traefik & Kubernetes
The Kubernetes Ingress Controller.
{: .subtitle }
## Routing Configuration
The provider then watches for incoming ingresses events, such as the example below,
and derives the corresponding dynamic configuration from it,
which in turn will create the resulting routers, services, handlers, etc.
2020-03-09 13:48:06 +01:00
## Configuration Example
2020-01-14 15:48:06 +01:00
2020-03-09 13:48:06 +01:00
??? example "Configuring Kubernetes Ingress Controller"
```yaml tab="RBAC"
---
kind: ClusterRole
apiVersion: rbac.authorization.k8s.io/v1beta1
metadata:
name: traefik-ingress-controller
rules:
- apiGroups:
- ""
resources:
- services
- endpoints
- secrets
verbs:
- get
- list
- watch
- apiGroups:
- extensions
2020-09-15 18:34:04 +02:00
- networking.k8s.io
2020-03-09 13:48:06 +01:00
resources:
- ingresses
2020-09-15 18:34:04 +02:00
- ingressclasses
2020-03-09 13:48:06 +01:00
verbs:
- get
- list
- watch
- apiGroups:
- extensions
resources:
- ingresses/status
verbs:
- update
---
kind: ClusterRoleBinding
apiVersion: rbac.authorization.k8s.io/v1beta1
metadata:
name: traefik-ingress-controller
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: ClusterRole
name: traefik-ingress-controller
subjects:
- kind: ServiceAccount
name: traefik-ingress-controller
namespace: default
```
2020-01-14 15:48:06 +01:00
```yaml tab="Ingress"
kind: Ingress
2020-01-16 10:14:06 +01:00
apiVersion: networking.k8s.io/v1beta1
2020-01-14 15:48:06 +01:00
metadata:
2020-03-09 13:48:06 +01:00
name: myingress
2020-01-14 15:48:06 +01:00
annotations:
traefik.ingress.kubernetes.io/router.entrypoints: web
spec:
rules:
2020-03-13 22:50:05 +01:00
- host: example.com
2020-03-09 13:48:06 +01:00
http:
paths:
- path: /bar
backend:
serviceName: whoami
servicePort: 80
- path: /foo
backend:
serviceName: whoami
servicePort: 80
2020-01-14 15:48:06 +01:00
```
2020-03-09 13:48:06 +01:00
```yaml tab="Traefik"
apiVersion: v1
kind: ServiceAccount
metadata:
name: traefik-ingress-controller
---
kind: Deployment
apiVersion: apps/v1
metadata:
name: traefik
labels:
app: traefik
spec:
replicas: 1
selector:
matchLabels:
app: traefik
template:
metadata:
labels:
app: traefik
spec:
serviceAccountName: traefik-ingress-controller
containers:
- name: traefik
2020-07-15 20:50:03 +02:00
image: traefik:v2.3
2020-03-09 13:48:06 +01:00
args:
- --log.level=DEBUG
- --api
- --api.insecure
- --entrypoints.web.address=:80
- --providers.kubernetesingress
ports:
- name: web
containerPort: 80
- name: admin
containerPort: 8080
---
apiVersion: v1
2020-01-14 15:48:06 +01:00
kind: Service
2020-03-09 13:48:06 +01:00
metadata:
name: traefik
spec:
type: LoadBalancer
selector:
app: traefik
ports:
- protocol: TCP
port: 80
name: web
targetPort: 80
- protocol: TCP
port: 8080
name: admin
targetPort: 8080
```
```yaml tab="Whoami"
kind: Deployment
apiVersion: apps/v1
metadata:
name: whoami
labels:
2020-09-16 15:46:04 +02:00
app: traefiklabs
2020-03-09 13:48:06 +01:00
name: whoami
spec:
replicas: 2
selector:
matchLabels:
2020-09-16 15:46:04 +02:00
app: traefiklabs
2020-03-09 13:48:06 +01:00
task: whoami
template:
metadata:
labels:
2020-09-16 15:46:04 +02:00
app: traefiklabs
2020-03-09 13:48:06 +01:00
task: whoami
spec:
containers:
2020-09-16 15:46:04 +02:00
- name: whoami
image: traefik/whoami
2020-03-09 13:48:06 +01:00
ports:
- containerPort: 80
---
2020-01-14 15:48:06 +01:00
apiVersion: v1
2020-03-09 13:48:06 +01:00
kind: Service
2020-01-14 15:48:06 +01:00
metadata:
2020-03-09 13:48:06 +01:00
name: whoami
2020-01-14 15:48:06 +01:00
spec:
ports:
2020-03-09 13:48:06 +01:00
- name: http
port: 80
selector:
2020-09-16 15:46:04 +02:00
app: traefiklabs
2020-03-09 13:48:06 +01:00
task: whoami
2020-01-14 15:48:06 +01:00
```
2020-03-09 13:48:06 +01:00
## Annotations
2020-01-14 15:48:06 +01:00
#### On Ingress
??? info "`traefik.ingress.kubernetes.io/router.entrypoints` "
See [entry points ](../routers/index.md#entrypoints ) for more information.
```yaml
traefik.ingress.kubernetes.io/router.entrypoints: ep1,ep2
```
??? info "`traefik.ingress.kubernetes.io/router.middlewares` "
See [middlewares ](../routers/index.md#middlewares ) and [middlewares overview ](../../middlewares/overview.md ) for more information.
```yaml
2020-05-27 17:48:04 +02:00
traefik.ingress.kubernetes.io/router.middlewares: auth@file ,prefix@kubernetescrd ,cb@file
2020-01-14 15:48:06 +01:00
```
??? info "`traefik.ingress.kubernetes.io/router.priority` "
See [priority ](../routers/index.md#priority ) for more information.
```yaml
traefik.ingress.kubernetes.io/router.priority: "42"
```
??? info "`traefik.ingress.kubernetes.io/router.pathmatcher` "
Overrides the default router rule type used for a path.
Only path-related matcher name can be specified: `Path` , `PathPrefix` .
Default `PathPrefix`
```yaml
traefik.ingress.kubernetes.io/router.pathmatcher: Path
```
??? info "`traefik.ingress.kubernetes.io/router.tls` "
See [tls ](../routers/index.md#tls ) for more information.
```yaml
traefik.ingress.kubernetes.io/router.tls: "true"
```
??? info "`traefik.ingress.kubernetes.io/router.tls.certresolver` "
See [certResolver ](../routers/index.md#certresolver ) for more information.
```yaml
traefik.ingress.kubernetes.io/router.tls.certresolver: myresolver
```
??? info "`traefik.ingress.kubernetes.io/router.tls.domains.n.main` "
See [domains ](../routers/index.md#domains ) for more information.
```yaml
2020-03-13 22:50:05 +01:00
traefik.ingress.kubernetes.io/router.tls.domains.0.main: example.org
2020-01-14 15:48:06 +01:00
```
??? info "`traefik.ingress.kubernetes.io/router.tls.domains.n.sans` "
See [domains ](../routers/index.md#domains ) for more information.
```yaml
2020-03-13 22:50:05 +01:00
traefik.ingress.kubernetes.io/router.tls.domains.0.sans: test.example.org,dev.example.org
2020-01-14 15:48:06 +01:00
```
??? info "`traefik.ingress.kubernetes.io/router.tls.options` "
See [options ](../routers/index.md#options ) for more information.
```yaml
traefik.ingress.kubernetes.io/router.tls.options: foobar
```
#### On Service
??? info "`traefik.ingress.kubernetes.io/service.serversscheme` "
Overrides the default scheme.
```yaml
traefik.ingress.kubernetes.io/service.serversscheme: h2c
```
??? info "`traefik.ingress.kubernetes.io/service.passhostheader` "
See [pass Host header ](../services/index.md#pass-host-header ) for more information.
```yaml
traefik.ingress.kubernetes.io/service.passhostheader: "true"
```
2020-07-01 12:58:05 +02:00
??? info "`traefik.ingress.kubernetes.io/service.sticky.cookie` "
2020-01-14 15:48:06 +01:00
See [sticky sessions ](../services/index.md#sticky-sessions ) for more information.
```yaml
2020-07-01 12:58:05 +02:00
traefik.ingress.kubernetes.io/service.sticky.cookie: "true"
2020-01-14 15:48:06 +01:00
```
2020-03-24 14:02:58 +01:00
??? info "`traefik.ingress.kubernetes.io/service.sticky.cookie.name` "
2020-01-14 15:48:06 +01:00
See [sticky sessions ](../services/index.md#sticky-sessions ) for more information.
```yaml
2020-03-24 14:02:58 +01:00
traefik.ingress.kubernetes.io/service.sticky.cookie.name: foobar
2020-01-14 15:48:06 +01:00
```
2020-03-24 14:02:58 +01:00
??? info "`traefik.ingress.kubernetes.io/service.sticky.cookie.secure` "
2020-01-14 15:48:06 +01:00
See [sticky sessions ](../services/index.md#sticky-sessions ) for more information.
```yaml
2020-03-24 14:02:58 +01:00
traefik.ingress.kubernetes.io/service.sticky.cookie.secure: "true"
2020-01-14 15:48:06 +01:00
```
2020-03-24 14:02:58 +01:00
??? info "`traefik.ingress.kubernetes.io/service.sticky.cookie.samesite` "
2020-01-14 15:48:06 +01:00
See [sticky sessions ](../services/index.md#sticky-sessions ) for more information.
```yaml
2020-03-24 14:02:58 +01:00
traefik.ingress.kubernetes.io/service.sticky.cookie.samesite: "none"
```
??? info "`traefik.ingress.kubernetes.io/service.sticky.cookie.httponly` "
See [sticky sessions ](../services/index.md#sticky-sessions ) for more information.
```yaml
traefik.ingress.kubernetes.io/service.sticky.cookie.httponly: "true"
2020-01-14 15:48:06 +01:00
```
2020-07-28 17:50:04 +02:00
## Path Types on Kubernetes 1.18+
If the Kubernetes cluster version is 1.18+,
the new `pathType` property can be leveraged to define the rules matchers:
2020-01-14 15:48:06 +01:00
2020-07-28 17:50:04 +02:00
- `Exact` : This path type forces the rule matcher to `Path`
- `Prefix` : This path type forces the rule matcher to `PathPrefix`
Please see [this documentation ](https://kubernetes.io/docs/concepts/services-networking/ingress/#path-types ) for more information.
!!! warning "Multiple Matches"
In the case of multiple matches, Traefik will not ensure the priority of a Path matcher over a PathPrefix matcher,
as stated in [this documentation ](https://kubernetes.io/docs/concepts/services-networking/ingress/#multiple-matches ).
## TLS
### Communication Between Traefik and Pods
2020-01-14 15:48:06 +01:00
Traefik automatically requests endpoint information based on the service provided in the ingress spec.
Although Traefik will connect directly to the endpoints (pods),
it still checks the service port to see if TLS communication is required.
There are 3 ways to configure Traefik to use https to communicate with pods:
1. If the service port defined in the ingress spec is `443` (note that you can still use `targetPort` to use a different port on your pod).
1. If the service port defined in the ingress spec has a name that starts with https (such as `https-api` , `https-web` or just `https` ).
1. If the ingress spec includes the annotation `traefik.ingress.kubernetes.io/service.serversscheme: https` .
If either of those configuration options exist, then the backend communication protocol is assumed to be TLS,
and will connect via TLS automatically.
!!! info
Please note that by enabling TLS communication between traefik and your pods,
you will have to have trusted certificates that have the proper trust chain and IP subject name.
If this is not an option, you may need to skip TLS certificate verification.
See the [insecureSkipVerify ](../../routing/overview.md#insecureskipverify ) setting for more details.
2020-07-28 17:50:04 +02:00
### Certificates Management
2020-01-14 15:48:06 +01:00
??? example "Using a secret"
```yaml tab="Ingress"
kind: Ingress
2020-01-16 10:14:06 +01:00
apiVersion: networking.k8s.io/v1beta1
2020-01-14 15:48:06 +01:00
metadata:
name: foo
namespace: production
spec:
rules:
2020-03-13 22:50:05 +01:00
- host: example.net
2020-01-14 15:48:06 +01:00
http:
paths:
- path: /bar
backend:
serviceName: service1
servicePort: 80
tls:
- secretName: supersecret
```
```yaml tab="Secret"
apiVersion: v1
kind: Secret
metadata:
name: supersecret
data:
tls.crt: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCi0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0=
tls.key: LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCi0tLS0tRU5EIFBSSVZBVEUgS0VZLS0tLS0=
```
TLS certificates can be managed in Secrets objects.
!!! info
Only TLS certificates provided by users can be stored in Kubernetes Secrets.
[Let's Encrypt ](../../https/acme.md ) certificates cannot be managed in Kubernetes Secrets yet.
## Global Default Backend Ingresses
Ingresses can be created that look like the following:
```yaml
2020-01-16 10:14:06 +01:00
apiVersion: networking.k8s.io/v1beta1
2020-01-14 15:48:06 +01:00
kind: Ingress
metadata:
name: cheese
spec:
backend:
serviceName: stilton
servicePort: 80
```
This ingress follows the Global Default Backend property of ingresses.
This will allow users to create a "default router" that will match all unmatched requests.
!!! info
Due to Traefik's use of priorities, you may have to set this ingress priority lower than other ingresses in your environment,
to avoid this global ingress from satisfying requests that could match other ingresses.
To do this, use the `traefik.ingress.kubernetes.io/router.priority` annotation (as seen in [Annotations on Ingress ](#on-ingress )) on your ingresses accordingly.