Add HealthCheck for KubernetesCRD ExternalName services
This commit is contained in:
parent
c0a2e6b4b6
commit
7fc56454ea
13 changed files with 885 additions and 22 deletions
|
@ -98,6 +98,47 @@ spec:
|
||||||
description: Service defines an upstream HTTP service to proxy
|
description: Service defines an upstream HTTP service to proxy
|
||||||
traffic to.
|
traffic to.
|
||||||
properties:
|
properties:
|
||||||
|
healthCheck:
|
||||||
|
description: Healthcheck defines health checks for the
|
||||||
|
service.
|
||||||
|
properties:
|
||||||
|
followRedirects:
|
||||||
|
type: boolean
|
||||||
|
headers:
|
||||||
|
additionalProperties:
|
||||||
|
type: string
|
||||||
|
type: object
|
||||||
|
hostname:
|
||||||
|
type: string
|
||||||
|
interval:
|
||||||
|
description: |-
|
||||||
|
Duration is a custom type suitable for parsing duration values.
|
||||||
|
It supports `time.ParseDuration`-compatible values and suffix-less digits; in
|
||||||
|
the latter case, seconds are assumed.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
method:
|
||||||
|
type: string
|
||||||
|
mode:
|
||||||
|
type: string
|
||||||
|
path:
|
||||||
|
type: string
|
||||||
|
port:
|
||||||
|
type: integer
|
||||||
|
scheme:
|
||||||
|
type: string
|
||||||
|
status:
|
||||||
|
type: integer
|
||||||
|
timeout:
|
||||||
|
description: |-
|
||||||
|
Duration is a custom type suitable for parsing duration values.
|
||||||
|
It supports `time.ParseDuration`-compatible values and suffix-less digits; in
|
||||||
|
the latter case, seconds are assumed.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
required:
|
||||||
|
- followRedirects
|
||||||
|
type: object
|
||||||
kind:
|
kind:
|
||||||
description: Kind defines the kind of the Service.
|
description: Kind defines the kind of the Service.
|
||||||
enum:
|
enum:
|
||||||
|
@ -919,6 +960,46 @@ spec:
|
||||||
Service defines the reference to a Kubernetes Service that will serve the error page.
|
Service defines the reference to a Kubernetes Service that will serve the error page.
|
||||||
More info: https://doc.traefik.io/traefik/v3.0/middlewares/http/errorpages/#service
|
More info: https://doc.traefik.io/traefik/v3.0/middlewares/http/errorpages/#service
|
||||||
properties:
|
properties:
|
||||||
|
healthCheck:
|
||||||
|
description: Healthcheck defines health checks for the service.
|
||||||
|
properties:
|
||||||
|
followRedirects:
|
||||||
|
type: boolean
|
||||||
|
headers:
|
||||||
|
additionalProperties:
|
||||||
|
type: string
|
||||||
|
type: object
|
||||||
|
hostname:
|
||||||
|
type: string
|
||||||
|
interval:
|
||||||
|
description: |-
|
||||||
|
Duration is a custom type suitable for parsing duration values.
|
||||||
|
It supports `time.ParseDuration`-compatible values and suffix-less digits; in
|
||||||
|
the latter case, seconds are assumed.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
method:
|
||||||
|
type: string
|
||||||
|
mode:
|
||||||
|
type: string
|
||||||
|
path:
|
||||||
|
type: string
|
||||||
|
port:
|
||||||
|
type: integer
|
||||||
|
scheme:
|
||||||
|
type: string
|
||||||
|
status:
|
||||||
|
type: integer
|
||||||
|
timeout:
|
||||||
|
description: |-
|
||||||
|
Duration is a custom type suitable for parsing duration values.
|
||||||
|
It supports `time.ParseDuration`-compatible values and suffix-less digits; in
|
||||||
|
the latter case, seconds are assumed.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
required:
|
||||||
|
- followRedirects
|
||||||
|
type: object
|
||||||
kind:
|
kind:
|
||||||
description: Kind defines the kind of the Service.
|
description: Kind defines the kind of the Service.
|
||||||
enum:
|
enum:
|
||||||
|
@ -2295,6 +2376,46 @@ spec:
|
||||||
mirroring:
|
mirroring:
|
||||||
description: Mirroring defines the Mirroring service configuration.
|
description: Mirroring defines the Mirroring service configuration.
|
||||||
properties:
|
properties:
|
||||||
|
healthCheck:
|
||||||
|
description: Healthcheck defines health checks for the service.
|
||||||
|
properties:
|
||||||
|
followRedirects:
|
||||||
|
type: boolean
|
||||||
|
headers:
|
||||||
|
additionalProperties:
|
||||||
|
type: string
|
||||||
|
type: object
|
||||||
|
hostname:
|
||||||
|
type: string
|
||||||
|
interval:
|
||||||
|
description: |-
|
||||||
|
Duration is a custom type suitable for parsing duration values.
|
||||||
|
It supports `time.ParseDuration`-compatible values and suffix-less digits; in
|
||||||
|
the latter case, seconds are assumed.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
method:
|
||||||
|
type: string
|
||||||
|
mode:
|
||||||
|
type: string
|
||||||
|
path:
|
||||||
|
type: string
|
||||||
|
port:
|
||||||
|
type: integer
|
||||||
|
scheme:
|
||||||
|
type: string
|
||||||
|
status:
|
||||||
|
type: integer
|
||||||
|
timeout:
|
||||||
|
description: |-
|
||||||
|
Duration is a custom type suitable for parsing duration values.
|
||||||
|
It supports `time.ParseDuration`-compatible values and suffix-less digits; in
|
||||||
|
the latter case, seconds are assumed.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
required:
|
||||||
|
- followRedirects
|
||||||
|
type: object
|
||||||
kind:
|
kind:
|
||||||
description: Kind defines the kind of the Service.
|
description: Kind defines the kind of the Service.
|
||||||
enum:
|
enum:
|
||||||
|
@ -2314,6 +2435,46 @@ spec:
|
||||||
items:
|
items:
|
||||||
description: MirrorService holds the mirror configuration.
|
description: MirrorService holds the mirror configuration.
|
||||||
properties:
|
properties:
|
||||||
|
healthCheck:
|
||||||
|
description: Healthcheck defines health checks for the service.
|
||||||
|
properties:
|
||||||
|
followRedirects:
|
||||||
|
type: boolean
|
||||||
|
headers:
|
||||||
|
additionalProperties:
|
||||||
|
type: string
|
||||||
|
type: object
|
||||||
|
hostname:
|
||||||
|
type: string
|
||||||
|
interval:
|
||||||
|
description: |-
|
||||||
|
Duration is a custom type suitable for parsing duration values.
|
||||||
|
It supports `time.ParseDuration`-compatible values and suffix-less digits; in
|
||||||
|
the latter case, seconds are assumed.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
method:
|
||||||
|
type: string
|
||||||
|
mode:
|
||||||
|
type: string
|
||||||
|
path:
|
||||||
|
type: string
|
||||||
|
port:
|
||||||
|
type: integer
|
||||||
|
scheme:
|
||||||
|
type: string
|
||||||
|
status:
|
||||||
|
type: integer
|
||||||
|
timeout:
|
||||||
|
description: |-
|
||||||
|
Duration is a custom type suitable for parsing duration values.
|
||||||
|
It supports `time.ParseDuration`-compatible values and suffix-less digits; in
|
||||||
|
the latter case, seconds are assumed.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
required:
|
||||||
|
- followRedirects
|
||||||
|
type: object
|
||||||
kind:
|
kind:
|
||||||
description: Kind defines the kind of the Service.
|
description: Kind defines the kind of the Service.
|
||||||
enum:
|
enum:
|
||||||
|
@ -2548,6 +2709,46 @@ spec:
|
||||||
description: Service defines an upstream HTTP service to proxy
|
description: Service defines an upstream HTTP service to proxy
|
||||||
traffic to.
|
traffic to.
|
||||||
properties:
|
properties:
|
||||||
|
healthCheck:
|
||||||
|
description: Healthcheck defines health checks for the service.
|
||||||
|
properties:
|
||||||
|
followRedirects:
|
||||||
|
type: boolean
|
||||||
|
headers:
|
||||||
|
additionalProperties:
|
||||||
|
type: string
|
||||||
|
type: object
|
||||||
|
hostname:
|
||||||
|
type: string
|
||||||
|
interval:
|
||||||
|
description: |-
|
||||||
|
Duration is a custom type suitable for parsing duration values.
|
||||||
|
It supports `time.ParseDuration`-compatible values and suffix-less digits; in
|
||||||
|
the latter case, seconds are assumed.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
method:
|
||||||
|
type: string
|
||||||
|
mode:
|
||||||
|
type: string
|
||||||
|
path:
|
||||||
|
type: string
|
||||||
|
port:
|
||||||
|
type: integer
|
||||||
|
scheme:
|
||||||
|
type: string
|
||||||
|
status:
|
||||||
|
type: integer
|
||||||
|
timeout:
|
||||||
|
description: |-
|
||||||
|
Duration is a custom type suitable for parsing duration values.
|
||||||
|
It supports `time.ParseDuration`-compatible values and suffix-less digits; in
|
||||||
|
the latter case, seconds are assumed.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
required:
|
||||||
|
- followRedirects
|
||||||
|
type: object
|
||||||
kind:
|
kind:
|
||||||
description: Kind defines the kind of the Service.
|
description: Kind defines the kind of the Service.
|
||||||
enum:
|
enum:
|
||||||
|
|
|
@ -98,6 +98,47 @@ spec:
|
||||||
description: Service defines an upstream HTTP service to proxy
|
description: Service defines an upstream HTTP service to proxy
|
||||||
traffic to.
|
traffic to.
|
||||||
properties:
|
properties:
|
||||||
|
healthCheck:
|
||||||
|
description: Healthcheck defines health checks for the
|
||||||
|
service.
|
||||||
|
properties:
|
||||||
|
followRedirects:
|
||||||
|
type: boolean
|
||||||
|
headers:
|
||||||
|
additionalProperties:
|
||||||
|
type: string
|
||||||
|
type: object
|
||||||
|
hostname:
|
||||||
|
type: string
|
||||||
|
interval:
|
||||||
|
description: |-
|
||||||
|
Duration is a custom type suitable for parsing duration values.
|
||||||
|
It supports `time.ParseDuration`-compatible values and suffix-less digits; in
|
||||||
|
the latter case, seconds are assumed.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
method:
|
||||||
|
type: string
|
||||||
|
mode:
|
||||||
|
type: string
|
||||||
|
path:
|
||||||
|
type: string
|
||||||
|
port:
|
||||||
|
type: integer
|
||||||
|
scheme:
|
||||||
|
type: string
|
||||||
|
status:
|
||||||
|
type: integer
|
||||||
|
timeout:
|
||||||
|
description: |-
|
||||||
|
Duration is a custom type suitable for parsing duration values.
|
||||||
|
It supports `time.ParseDuration`-compatible values and suffix-less digits; in
|
||||||
|
the latter case, seconds are assumed.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
required:
|
||||||
|
- followRedirects
|
||||||
|
type: object
|
||||||
kind:
|
kind:
|
||||||
description: Kind defines the kind of the Service.
|
description: Kind defines the kind of the Service.
|
||||||
enum:
|
enum:
|
||||||
|
|
|
@ -256,6 +256,46 @@ spec:
|
||||||
Service defines the reference to a Kubernetes Service that will serve the error page.
|
Service defines the reference to a Kubernetes Service that will serve the error page.
|
||||||
More info: https://doc.traefik.io/traefik/v3.0/middlewares/http/errorpages/#service
|
More info: https://doc.traefik.io/traefik/v3.0/middlewares/http/errorpages/#service
|
||||||
properties:
|
properties:
|
||||||
|
healthCheck:
|
||||||
|
description: Healthcheck defines health checks for the service.
|
||||||
|
properties:
|
||||||
|
followRedirects:
|
||||||
|
type: boolean
|
||||||
|
headers:
|
||||||
|
additionalProperties:
|
||||||
|
type: string
|
||||||
|
type: object
|
||||||
|
hostname:
|
||||||
|
type: string
|
||||||
|
interval:
|
||||||
|
description: |-
|
||||||
|
Duration is a custom type suitable for parsing duration values.
|
||||||
|
It supports `time.ParseDuration`-compatible values and suffix-less digits; in
|
||||||
|
the latter case, seconds are assumed.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
method:
|
||||||
|
type: string
|
||||||
|
mode:
|
||||||
|
type: string
|
||||||
|
path:
|
||||||
|
type: string
|
||||||
|
port:
|
||||||
|
type: integer
|
||||||
|
scheme:
|
||||||
|
type: string
|
||||||
|
status:
|
||||||
|
type: integer
|
||||||
|
timeout:
|
||||||
|
description: |-
|
||||||
|
Duration is a custom type suitable for parsing duration values.
|
||||||
|
It supports `time.ParseDuration`-compatible values and suffix-less digits; in
|
||||||
|
the latter case, seconds are assumed.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
required:
|
||||||
|
- followRedirects
|
||||||
|
type: object
|
||||||
kind:
|
kind:
|
||||||
description: Kind defines the kind of the Service.
|
description: Kind defines the kind of the Service.
|
||||||
enum:
|
enum:
|
||||||
|
|
|
@ -47,6 +47,46 @@ spec:
|
||||||
mirroring:
|
mirroring:
|
||||||
description: Mirroring defines the Mirroring service configuration.
|
description: Mirroring defines the Mirroring service configuration.
|
||||||
properties:
|
properties:
|
||||||
|
healthCheck:
|
||||||
|
description: Healthcheck defines health checks for the service.
|
||||||
|
properties:
|
||||||
|
followRedirects:
|
||||||
|
type: boolean
|
||||||
|
headers:
|
||||||
|
additionalProperties:
|
||||||
|
type: string
|
||||||
|
type: object
|
||||||
|
hostname:
|
||||||
|
type: string
|
||||||
|
interval:
|
||||||
|
description: |-
|
||||||
|
Duration is a custom type suitable for parsing duration values.
|
||||||
|
It supports `time.ParseDuration`-compatible values and suffix-less digits; in
|
||||||
|
the latter case, seconds are assumed.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
method:
|
||||||
|
type: string
|
||||||
|
mode:
|
||||||
|
type: string
|
||||||
|
path:
|
||||||
|
type: string
|
||||||
|
port:
|
||||||
|
type: integer
|
||||||
|
scheme:
|
||||||
|
type: string
|
||||||
|
status:
|
||||||
|
type: integer
|
||||||
|
timeout:
|
||||||
|
description: |-
|
||||||
|
Duration is a custom type suitable for parsing duration values.
|
||||||
|
It supports `time.ParseDuration`-compatible values and suffix-less digits; in
|
||||||
|
the latter case, seconds are assumed.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
required:
|
||||||
|
- followRedirects
|
||||||
|
type: object
|
||||||
kind:
|
kind:
|
||||||
description: Kind defines the kind of the Service.
|
description: Kind defines the kind of the Service.
|
||||||
enum:
|
enum:
|
||||||
|
@ -66,6 +106,46 @@ spec:
|
||||||
items:
|
items:
|
||||||
description: MirrorService holds the mirror configuration.
|
description: MirrorService holds the mirror configuration.
|
||||||
properties:
|
properties:
|
||||||
|
healthCheck:
|
||||||
|
description: Healthcheck defines health checks for the service.
|
||||||
|
properties:
|
||||||
|
followRedirects:
|
||||||
|
type: boolean
|
||||||
|
headers:
|
||||||
|
additionalProperties:
|
||||||
|
type: string
|
||||||
|
type: object
|
||||||
|
hostname:
|
||||||
|
type: string
|
||||||
|
interval:
|
||||||
|
description: |-
|
||||||
|
Duration is a custom type suitable for parsing duration values.
|
||||||
|
It supports `time.ParseDuration`-compatible values and suffix-less digits; in
|
||||||
|
the latter case, seconds are assumed.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
method:
|
||||||
|
type: string
|
||||||
|
mode:
|
||||||
|
type: string
|
||||||
|
path:
|
||||||
|
type: string
|
||||||
|
port:
|
||||||
|
type: integer
|
||||||
|
scheme:
|
||||||
|
type: string
|
||||||
|
status:
|
||||||
|
type: integer
|
||||||
|
timeout:
|
||||||
|
description: |-
|
||||||
|
Duration is a custom type suitable for parsing duration values.
|
||||||
|
It supports `time.ParseDuration`-compatible values and suffix-less digits; in
|
||||||
|
the latter case, seconds are assumed.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
required:
|
||||||
|
- followRedirects
|
||||||
|
type: object
|
||||||
kind:
|
kind:
|
||||||
description: Kind defines the kind of the Service.
|
description: Kind defines the kind of the Service.
|
||||||
enum:
|
enum:
|
||||||
|
@ -300,6 +380,46 @@ spec:
|
||||||
description: Service defines an upstream HTTP service to proxy
|
description: Service defines an upstream HTTP service to proxy
|
||||||
traffic to.
|
traffic to.
|
||||||
properties:
|
properties:
|
||||||
|
healthCheck:
|
||||||
|
description: Healthcheck defines health checks for the service.
|
||||||
|
properties:
|
||||||
|
followRedirects:
|
||||||
|
type: boolean
|
||||||
|
headers:
|
||||||
|
additionalProperties:
|
||||||
|
type: string
|
||||||
|
type: object
|
||||||
|
hostname:
|
||||||
|
type: string
|
||||||
|
interval:
|
||||||
|
description: |-
|
||||||
|
Duration is a custom type suitable for parsing duration values.
|
||||||
|
It supports `time.ParseDuration`-compatible values and suffix-less digits; in
|
||||||
|
the latter case, seconds are assumed.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
method:
|
||||||
|
type: string
|
||||||
|
mode:
|
||||||
|
type: string
|
||||||
|
path:
|
||||||
|
type: string
|
||||||
|
port:
|
||||||
|
type: integer
|
||||||
|
scheme:
|
||||||
|
type: string
|
||||||
|
status:
|
||||||
|
type: integer
|
||||||
|
timeout:
|
||||||
|
description: |-
|
||||||
|
Duration is a custom type suitable for parsing duration values.
|
||||||
|
It supports `time.ParseDuration`-compatible values and suffix-less digits; in
|
||||||
|
the latter case, seconds are assumed.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
required:
|
||||||
|
- followRedirects
|
||||||
|
type: object
|
||||||
kind:
|
kind:
|
||||||
description: Kind defines the kind of the Service.
|
description: Kind defines the kind of the Service.
|
||||||
enum:
|
enum:
|
||||||
|
|
|
@ -342,6 +342,9 @@ Register the `IngressRoute` [kind](../../reference/dynamic-configuration/kuberne
|
||||||
flushInterval: 1ms
|
flushInterval: 1ms
|
||||||
scheme: https
|
scheme: https
|
||||||
serversTransport: transport # [10]
|
serversTransport: transport # [10]
|
||||||
|
healthCheck: # [11]
|
||||||
|
path: /health
|
||||||
|
interval: 15s
|
||||||
sticky:
|
sticky:
|
||||||
cookie:
|
cookie:
|
||||||
httpOnly: true
|
httpOnly: true
|
||||||
|
@ -351,17 +354,17 @@ Register the `IngressRoute` [kind](../../reference/dynamic-configuration/kuberne
|
||||||
maxAge: 42
|
maxAge: 42
|
||||||
strategy: RoundRobin
|
strategy: RoundRobin
|
||||||
weight: 10
|
weight: 10
|
||||||
nativeLB: true # [11]
|
nativeLB: true # [12]
|
||||||
nodePortLB: true # [12]
|
nodePortLB: true # [13]
|
||||||
tls: # [13]
|
tls: # [14]
|
||||||
secretName: supersecret # [14]
|
secretName: supersecret # [15]
|
||||||
options: # [15]
|
options: # [16]
|
||||||
name: opt # [16]
|
name: opt # [17]
|
||||||
namespace: default # [17]
|
namespace: default # [18]
|
||||||
certResolver: foo # [18]
|
certResolver: foo # [19]
|
||||||
domains: # [19]
|
domains: # [20]
|
||||||
- main: example.net # [20]
|
- main: example.net # [21]
|
||||||
sans: # [21]
|
sans: # [22]
|
||||||
- a.example.net
|
- a.example.net
|
||||||
- b.example.net
|
- b.example.net
|
||||||
```
|
```
|
||||||
|
@ -378,17 +381,18 @@ Register the `IngressRoute` [kind](../../reference/dynamic-configuration/kuberne
|
||||||
| [8] | `routes[n].services` | List of any combination of [TraefikService](#kind-traefikservice) and reference to a [Kubernetes service](https://kubernetes.io/docs/concepts/services-networking/service/) (See below for `ExternalName Service` setup) |
|
| [8] | `routes[n].services` | List of any combination of [TraefikService](#kind-traefikservice) and reference to a [Kubernetes service](https://kubernetes.io/docs/concepts/services-networking/service/) (See below for `ExternalName Service` setup) |
|
||||||
| [9] | `services[n].port` | Defines the port of a [Kubernetes service](https://kubernetes.io/docs/concepts/services-networking/service/). This can be a reference to a named port. |
|
| [9] | `services[n].port` | Defines the port of a [Kubernetes service](https://kubernetes.io/docs/concepts/services-networking/service/). This can be a reference to a named port. |
|
||||||
| [10] | `services[n].serversTransport` | Defines the reference to a [ServersTransport](#kind-serverstransport). The ServersTransport namespace is assumed to be the [Kubernetes service](https://kubernetes.io/docs/concepts/services-networking/service/) namespace (see [ServersTransport reference](#serverstransport-reference)). |
|
| [10] | `services[n].serversTransport` | Defines the reference to a [ServersTransport](#kind-serverstransport). The ServersTransport namespace is assumed to be the [Kubernetes service](https://kubernetes.io/docs/concepts/services-networking/service/) namespace (see [ServersTransport reference](#serverstransport-reference)). |
|
||||||
| [11] | `services[n].nativeLB` | Controls, when creating the load-balancer, whether the LB's children are directly the pods IPs or if the only child is the Kubernetes Service clusterIP. |
|
| [11] | `services[n].healthCheck` | Defines the HealthCheck when service references a [Kubernetes service](https://kubernetes.io/docs/concepts/services-networking/service/) of type ExternalName. |
|
||||||
| [12] | `services[n].nodePortLB` | Controls, when creating the load-balancer, whether the LB's children are directly the nodes internal IPs using the nodePort when the service type is NodePort. |
|
| [12] | `services[n].nativeLB` | Controls, when creating the load-balancer, whether the LB's children are directly the pods IPs or if the only child is the Kubernetes Service clusterIP. |
|
||||||
| [13] | `tls` | Defines [TLS](../routers/index.md#tls) certificate configuration |
|
| [13] | `services[n].nodePortLB` | Controls, when creating the load-balancer, whether the LB's children are directly the nodes internal IPs using the nodePort when the service type is NodePort. |
|
||||||
| [14] | `tls.secretName` | Defines the [secret](https://kubernetes.io/docs/concepts/configuration/secret/) name used to store the certificate (in the `IngressRoute` namespace) |
|
| [14] | `tls` | Defines [TLS](../routers/index.md#tls) certificate configuration |
|
||||||
| [15] | `tls.options` | Defines the reference to a [TLSOption](#kind-tlsoption) |
|
| [15] | `tls.secretName` | Defines the [secret](https://kubernetes.io/docs/concepts/configuration/secret/) name used to store the certificate (in the `IngressRoute` namespace) |
|
||||||
| [16] | `options.name` | Defines the [TLSOption](#kind-tlsoption) name |
|
| [16] | `tls.options` | Defines the reference to a [TLSOption](#kind-tlsoption) |
|
||||||
| [17] | `options.namespace` | Defines the [TLSOption](#kind-tlsoption) namespace |
|
| [17] | `options.name` | Defines the [TLSOption](#kind-tlsoption) name |
|
||||||
| [18] | `tls.certResolver` | Defines the reference to a [CertResolver](../routers/index.md#certresolver) |
|
| [18] | `options.namespace` | Defines the [TLSOption](#kind-tlsoption) namespace |
|
||||||
| [19] | `tls.domains` | List of [domains](../routers/index.md#domains) |
|
| [19] | `tls.certResolver` | Defines the reference to a [CertResolver](../routers/index.md#certresolver) |
|
||||||
| [20] | `domains[n].main` | Defines the main domain name |
|
| [20] | `tls.domains` | List of [domains](../routers/index.md#domains) |
|
||||||
| [21] | `domains[n].sans` | List of SANs (alternative domains) |
|
| [21] | `domains[n].main` | Defines the main domain name |
|
||||||
|
| [22] | `domains[n].sans` | List of SANs (alternative domains) |
|
||||||
|
|
||||||
??? example "Declaring an IngressRoute"
|
??? example "Declaring an IngressRoute"
|
||||||
|
|
||||||
|
|
|
@ -98,6 +98,47 @@ spec:
|
||||||
description: Service defines an upstream HTTP service to proxy
|
description: Service defines an upstream HTTP service to proxy
|
||||||
traffic to.
|
traffic to.
|
||||||
properties:
|
properties:
|
||||||
|
healthCheck:
|
||||||
|
description: Healthcheck defines health checks for the
|
||||||
|
service.
|
||||||
|
properties:
|
||||||
|
followRedirects:
|
||||||
|
type: boolean
|
||||||
|
headers:
|
||||||
|
additionalProperties:
|
||||||
|
type: string
|
||||||
|
type: object
|
||||||
|
hostname:
|
||||||
|
type: string
|
||||||
|
interval:
|
||||||
|
description: |-
|
||||||
|
Duration is a custom type suitable for parsing duration values.
|
||||||
|
It supports `time.ParseDuration`-compatible values and suffix-less digits; in
|
||||||
|
the latter case, seconds are assumed.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
method:
|
||||||
|
type: string
|
||||||
|
mode:
|
||||||
|
type: string
|
||||||
|
path:
|
||||||
|
type: string
|
||||||
|
port:
|
||||||
|
type: integer
|
||||||
|
scheme:
|
||||||
|
type: string
|
||||||
|
status:
|
||||||
|
type: integer
|
||||||
|
timeout:
|
||||||
|
description: |-
|
||||||
|
Duration is a custom type suitable for parsing duration values.
|
||||||
|
It supports `time.ParseDuration`-compatible values and suffix-less digits; in
|
||||||
|
the latter case, seconds are assumed.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
required:
|
||||||
|
- followRedirects
|
||||||
|
type: object
|
||||||
kind:
|
kind:
|
||||||
description: Kind defines the kind of the Service.
|
description: Kind defines the kind of the Service.
|
||||||
enum:
|
enum:
|
||||||
|
@ -919,6 +960,46 @@ spec:
|
||||||
Service defines the reference to a Kubernetes Service that will serve the error page.
|
Service defines the reference to a Kubernetes Service that will serve the error page.
|
||||||
More info: https://doc.traefik.io/traefik/v3.0/middlewares/http/errorpages/#service
|
More info: https://doc.traefik.io/traefik/v3.0/middlewares/http/errorpages/#service
|
||||||
properties:
|
properties:
|
||||||
|
healthCheck:
|
||||||
|
description: Healthcheck defines health checks for the service.
|
||||||
|
properties:
|
||||||
|
followRedirects:
|
||||||
|
type: boolean
|
||||||
|
headers:
|
||||||
|
additionalProperties:
|
||||||
|
type: string
|
||||||
|
type: object
|
||||||
|
hostname:
|
||||||
|
type: string
|
||||||
|
interval:
|
||||||
|
description: |-
|
||||||
|
Duration is a custom type suitable for parsing duration values.
|
||||||
|
It supports `time.ParseDuration`-compatible values and suffix-less digits; in
|
||||||
|
the latter case, seconds are assumed.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
method:
|
||||||
|
type: string
|
||||||
|
mode:
|
||||||
|
type: string
|
||||||
|
path:
|
||||||
|
type: string
|
||||||
|
port:
|
||||||
|
type: integer
|
||||||
|
scheme:
|
||||||
|
type: string
|
||||||
|
status:
|
||||||
|
type: integer
|
||||||
|
timeout:
|
||||||
|
description: |-
|
||||||
|
Duration is a custom type suitable for parsing duration values.
|
||||||
|
It supports `time.ParseDuration`-compatible values and suffix-less digits; in
|
||||||
|
the latter case, seconds are assumed.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
required:
|
||||||
|
- followRedirects
|
||||||
|
type: object
|
||||||
kind:
|
kind:
|
||||||
description: Kind defines the kind of the Service.
|
description: Kind defines the kind of the Service.
|
||||||
enum:
|
enum:
|
||||||
|
@ -2295,6 +2376,46 @@ spec:
|
||||||
mirroring:
|
mirroring:
|
||||||
description: Mirroring defines the Mirroring service configuration.
|
description: Mirroring defines the Mirroring service configuration.
|
||||||
properties:
|
properties:
|
||||||
|
healthCheck:
|
||||||
|
description: Healthcheck defines health checks for the service.
|
||||||
|
properties:
|
||||||
|
followRedirects:
|
||||||
|
type: boolean
|
||||||
|
headers:
|
||||||
|
additionalProperties:
|
||||||
|
type: string
|
||||||
|
type: object
|
||||||
|
hostname:
|
||||||
|
type: string
|
||||||
|
interval:
|
||||||
|
description: |-
|
||||||
|
Duration is a custom type suitable for parsing duration values.
|
||||||
|
It supports `time.ParseDuration`-compatible values and suffix-less digits; in
|
||||||
|
the latter case, seconds are assumed.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
method:
|
||||||
|
type: string
|
||||||
|
mode:
|
||||||
|
type: string
|
||||||
|
path:
|
||||||
|
type: string
|
||||||
|
port:
|
||||||
|
type: integer
|
||||||
|
scheme:
|
||||||
|
type: string
|
||||||
|
status:
|
||||||
|
type: integer
|
||||||
|
timeout:
|
||||||
|
description: |-
|
||||||
|
Duration is a custom type suitable for parsing duration values.
|
||||||
|
It supports `time.ParseDuration`-compatible values and suffix-less digits; in
|
||||||
|
the latter case, seconds are assumed.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
required:
|
||||||
|
- followRedirects
|
||||||
|
type: object
|
||||||
kind:
|
kind:
|
||||||
description: Kind defines the kind of the Service.
|
description: Kind defines the kind of the Service.
|
||||||
enum:
|
enum:
|
||||||
|
@ -2314,6 +2435,46 @@ spec:
|
||||||
items:
|
items:
|
||||||
description: MirrorService holds the mirror configuration.
|
description: MirrorService holds the mirror configuration.
|
||||||
properties:
|
properties:
|
||||||
|
healthCheck:
|
||||||
|
description: Healthcheck defines health checks for the service.
|
||||||
|
properties:
|
||||||
|
followRedirects:
|
||||||
|
type: boolean
|
||||||
|
headers:
|
||||||
|
additionalProperties:
|
||||||
|
type: string
|
||||||
|
type: object
|
||||||
|
hostname:
|
||||||
|
type: string
|
||||||
|
interval:
|
||||||
|
description: |-
|
||||||
|
Duration is a custom type suitable for parsing duration values.
|
||||||
|
It supports `time.ParseDuration`-compatible values and suffix-less digits; in
|
||||||
|
the latter case, seconds are assumed.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
method:
|
||||||
|
type: string
|
||||||
|
mode:
|
||||||
|
type: string
|
||||||
|
path:
|
||||||
|
type: string
|
||||||
|
port:
|
||||||
|
type: integer
|
||||||
|
scheme:
|
||||||
|
type: string
|
||||||
|
status:
|
||||||
|
type: integer
|
||||||
|
timeout:
|
||||||
|
description: |-
|
||||||
|
Duration is a custom type suitable for parsing duration values.
|
||||||
|
It supports `time.ParseDuration`-compatible values and suffix-less digits; in
|
||||||
|
the latter case, seconds are assumed.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
required:
|
||||||
|
- followRedirects
|
||||||
|
type: object
|
||||||
kind:
|
kind:
|
||||||
description: Kind defines the kind of the Service.
|
description: Kind defines the kind of the Service.
|
||||||
enum:
|
enum:
|
||||||
|
@ -2548,6 +2709,46 @@ spec:
|
||||||
description: Service defines an upstream HTTP service to proxy
|
description: Service defines an upstream HTTP service to proxy
|
||||||
traffic to.
|
traffic to.
|
||||||
properties:
|
properties:
|
||||||
|
healthCheck:
|
||||||
|
description: Healthcheck defines health checks for the service.
|
||||||
|
properties:
|
||||||
|
followRedirects:
|
||||||
|
type: boolean
|
||||||
|
headers:
|
||||||
|
additionalProperties:
|
||||||
|
type: string
|
||||||
|
type: object
|
||||||
|
hostname:
|
||||||
|
type: string
|
||||||
|
interval:
|
||||||
|
description: |-
|
||||||
|
Duration is a custom type suitable for parsing duration values.
|
||||||
|
It supports `time.ParseDuration`-compatible values and suffix-less digits; in
|
||||||
|
the latter case, seconds are assumed.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
method:
|
||||||
|
type: string
|
||||||
|
mode:
|
||||||
|
type: string
|
||||||
|
path:
|
||||||
|
type: string
|
||||||
|
port:
|
||||||
|
type: integer
|
||||||
|
scheme:
|
||||||
|
type: string
|
||||||
|
status:
|
||||||
|
type: integer
|
||||||
|
timeout:
|
||||||
|
description: |-
|
||||||
|
Duration is a custom type suitable for parsing duration values.
|
||||||
|
It supports `time.ParseDuration`-compatible values and suffix-less digits; in
|
||||||
|
the latter case, seconds are assumed.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
required:
|
||||||
|
- followRedirects
|
||||||
|
type: object
|
||||||
kind:
|
kind:
|
||||||
description: Kind defines the kind of the Service.
|
description: Kind defines the kind of the Service.
|
||||||
enum:
|
enum:
|
||||||
|
|
|
@ -0,0 +1,22 @@
|
||||||
|
---
|
||||||
|
apiVersion: traefik.io/v1alpha1
|
||||||
|
kind: IngressRoute
|
||||||
|
metadata:
|
||||||
|
name: test.route
|
||||||
|
namespace: default
|
||||||
|
|
||||||
|
spec:
|
||||||
|
entryPoints:
|
||||||
|
- foo
|
||||||
|
|
||||||
|
routes:
|
||||||
|
- match: Host(`foo.com`) && PathPrefix(`/foo`)
|
||||||
|
kind: Rule
|
||||||
|
priority: 12
|
||||||
|
|
||||||
|
services:
|
||||||
|
- name: external-svc
|
||||||
|
port: 443
|
||||||
|
healthCheck:
|
||||||
|
path: /health
|
||||||
|
interval: 15s
|
|
@ -0,0 +1,27 @@
|
||||||
|
---
|
||||||
|
apiVersion: traefik.io/v1alpha1
|
||||||
|
kind: IngressRoute
|
||||||
|
metadata:
|
||||||
|
name: test.route
|
||||||
|
namespace: default
|
||||||
|
|
||||||
|
spec:
|
||||||
|
entryPoints:
|
||||||
|
- foo
|
||||||
|
|
||||||
|
routes:
|
||||||
|
- match: Host(`foo.com`) && PathPrefix(`/foo`)
|
||||||
|
kind: Rule
|
||||||
|
priority: 12
|
||||||
|
|
||||||
|
services:
|
||||||
|
- name: external-svc
|
||||||
|
port: 443
|
||||||
|
healthCheck:
|
||||||
|
path: /health1
|
||||||
|
interval: 15s
|
||||||
|
- name: whoami2
|
||||||
|
port: 443
|
||||||
|
healthCheck:
|
||||||
|
path: /health3
|
||||||
|
interval: 30s
|
|
@ -0,0 +1,27 @@
|
||||||
|
---
|
||||||
|
apiVersion: traefik.io/v1alpha1
|
||||||
|
kind: IngressRoute
|
||||||
|
metadata:
|
||||||
|
name: test.route
|
||||||
|
namespace: default
|
||||||
|
|
||||||
|
spec:
|
||||||
|
entryPoints:
|
||||||
|
- foo
|
||||||
|
|
||||||
|
routes:
|
||||||
|
- match: Host(`foo.com`) && PathPrefix(`/foo`)
|
||||||
|
kind: Rule
|
||||||
|
priority: 12
|
||||||
|
|
||||||
|
services:
|
||||||
|
- name: external-svc
|
||||||
|
port: 443
|
||||||
|
healthCheck:
|
||||||
|
path: /health1
|
||||||
|
interval: 15s
|
||||||
|
- name: external-svc-with-https
|
||||||
|
port: 443
|
||||||
|
healthCheck:
|
||||||
|
path: /health2
|
||||||
|
interval: 20s
|
|
@ -305,6 +305,7 @@ func (c configBuilder) buildServersLB(namespace string, svc traefikv1alpha1.Load
|
||||||
lb := &dynamic.ServersLoadBalancer{}
|
lb := &dynamic.ServersLoadBalancer{}
|
||||||
lb.SetDefaults()
|
lb.SetDefaults()
|
||||||
lb.Servers = servers
|
lb.Servers = servers
|
||||||
|
lb.HealthCheck = svc.HealthCheck
|
||||||
|
|
||||||
conf := svc
|
conf := svc
|
||||||
lb.PassHostHeader = conf.PassHostHeader
|
lb.PassHostHeader = conf.PassHostHeader
|
||||||
|
@ -380,6 +381,10 @@ func (c configBuilder) loadServers(parentNamespace string, svc traefikv1alpha1.L
|
||||||
}
|
}
|
||||||
|
|
||||||
var servers []dynamic.Server
|
var servers []dynamic.Server
|
||||||
|
if service.Spec.Type != corev1.ServiceTypeExternalName && svc.HealthCheck != nil {
|
||||||
|
return nil, fmt.Errorf("HealthCheck allowed only for ExternalName services: %s/%s", namespace, sanitizedName)
|
||||||
|
}
|
||||||
|
|
||||||
if service.Spec.Type == corev1.ServiceTypeExternalName {
|
if service.Spec.Type == corev1.ServiceTypeExternalName {
|
||||||
if !c.allowExternalNameServices {
|
if !c.allowExternalNameServices {
|
||||||
return nil, fmt.Errorf("externalName services not allowed: %s/%s", namespace, sanitizedName)
|
return nil, fmt.Errorf("externalName services not allowed: %s/%s", namespace, sanitizedName)
|
||||||
|
|
|
@ -2432,6 +2432,174 @@ func TestLoadIngressRoutes(t *testing.T) {
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
desc: "with one external service and health check",
|
||||||
|
paths: []string{"services.yml", "with_one_external_service_and_health_check.yml"},
|
||||||
|
expected: &dynamic.Configuration{
|
||||||
|
UDP: &dynamic.UDPConfiguration{
|
||||||
|
Routers: map[string]*dynamic.UDPRouter{},
|
||||||
|
Services: map[string]*dynamic.UDPService{},
|
||||||
|
},
|
||||||
|
TCP: &dynamic.TCPConfiguration{
|
||||||
|
Routers: map[string]*dynamic.TCPRouter{},
|
||||||
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
||||||
|
Services: map[string]*dynamic.TCPService{},
|
||||||
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
||||||
|
},
|
||||||
|
HTTP: &dynamic.HTTPConfiguration{
|
||||||
|
Routers: map[string]*dynamic.Router{
|
||||||
|
"default-test-route-77c62dfe9517144aeeaa": {
|
||||||
|
EntryPoints: []string{"foo"},
|
||||||
|
Service: "default-test-route-77c62dfe9517144aeeaa",
|
||||||
|
Rule: "Host(`foo.com`) && PathPrefix(`/foo`)",
|
||||||
|
Priority: 12,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Middlewares: map[string]*dynamic.Middleware{},
|
||||||
|
Services: map[string]*dynamic.Service{
|
||||||
|
"default-test-route-77c62dfe9517144aeeaa": {
|
||||||
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
||||||
|
Servers: []dynamic.Server{
|
||||||
|
{
|
||||||
|
URL: "https://external.domain:443",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
PassHostHeader: Bool(true),
|
||||||
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
||||||
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
||||||
|
},
|
||||||
|
HealthCheck: &dynamic.ServerHealthCheck{
|
||||||
|
Path: "/health",
|
||||||
|
Interval: 15000000000,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
||||||
|
},
|
||||||
|
TLS: &dynamic.TLSConfiguration{},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
desc: "with two external services and health check",
|
||||||
|
paths: []string{"services.yml", "with_two_external_services_and_health_check.yml"},
|
||||||
|
expected: &dynamic.Configuration{
|
||||||
|
UDP: &dynamic.UDPConfiguration{
|
||||||
|
Routers: map[string]*dynamic.UDPRouter{},
|
||||||
|
Services: map[string]*dynamic.UDPService{},
|
||||||
|
},
|
||||||
|
TCP: &dynamic.TCPConfiguration{
|
||||||
|
Routers: map[string]*dynamic.TCPRouter{},
|
||||||
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
||||||
|
Services: map[string]*dynamic.TCPService{},
|
||||||
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
||||||
|
},
|
||||||
|
HTTP: &dynamic.HTTPConfiguration{
|
||||||
|
Routers: map[string]*dynamic.Router{
|
||||||
|
"default-test-route-77c62dfe9517144aeeaa": {
|
||||||
|
EntryPoints: []string{"foo"},
|
||||||
|
Service: "default-test-route-77c62dfe9517144aeeaa",
|
||||||
|
Rule: "Host(`foo.com`) && PathPrefix(`/foo`)",
|
||||||
|
Priority: 12,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Middlewares: map[string]*dynamic.Middleware{},
|
||||||
|
Services: map[string]*dynamic.Service{
|
||||||
|
"default-test-route-77c62dfe9517144aeeaa": {
|
||||||
|
Weighted: &dynamic.WeightedRoundRobin{
|
||||||
|
Services: []dynamic.WRRService{
|
||||||
|
{
|
||||||
|
Name: "default-external-svc-443",
|
||||||
|
Weight: func(i int) *int { return &i }(1),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Name: "default-external-svc-with-https-443",
|
||||||
|
Weight: func(i int) *int { return &i }(1),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
"default-external-svc-443": {
|
||||||
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
||||||
|
Servers: []dynamic.Server{
|
||||||
|
{
|
||||||
|
URL: "https://external.domain:443",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
PassHostHeader: Bool(true),
|
||||||
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
||||||
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
||||||
|
},
|
||||||
|
HealthCheck: &dynamic.ServerHealthCheck{
|
||||||
|
Path: "/health1",
|
||||||
|
Interval: 15000000000,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
"default-external-svc-with-https-443": {
|
||||||
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
||||||
|
Servers: []dynamic.Server{
|
||||||
|
{
|
||||||
|
URL: "https://external.domain:443",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
PassHostHeader: Bool(true),
|
||||||
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
||||||
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
||||||
|
},
|
||||||
|
HealthCheck: &dynamic.ServerHealthCheck{
|
||||||
|
Path: "/health2",
|
||||||
|
Interval: 20000000000,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
||||||
|
},
|
||||||
|
TLS: &dynamic.TLSConfiguration{},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
desc: "with one external service and one regular service and health check",
|
||||||
|
paths: []string{"services.yml", "with_one_external_svc_and_regular_svc_health_check.yml"},
|
||||||
|
expected: &dynamic.Configuration{
|
||||||
|
UDP: &dynamic.UDPConfiguration{
|
||||||
|
Routers: map[string]*dynamic.UDPRouter{},
|
||||||
|
Services: map[string]*dynamic.UDPService{},
|
||||||
|
},
|
||||||
|
TCP: &dynamic.TCPConfiguration{
|
||||||
|
Routers: map[string]*dynamic.TCPRouter{},
|
||||||
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
||||||
|
Services: map[string]*dynamic.TCPService{},
|
||||||
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
||||||
|
},
|
||||||
|
HTTP: &dynamic.HTTPConfiguration{
|
||||||
|
Routers: map[string]*dynamic.Router{},
|
||||||
|
Middlewares: map[string]*dynamic.Middleware{},
|
||||||
|
Services: map[string]*dynamic.Service{
|
||||||
|
"default-external-svc-443": {
|
||||||
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
||||||
|
Servers: []dynamic.Server{
|
||||||
|
{
|
||||||
|
URL: "https://external.domain:443",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
PassHostHeader: Bool(true),
|
||||||
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
||||||
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
||||||
|
},
|
||||||
|
HealthCheck: &dynamic.ServerHealthCheck{
|
||||||
|
Path: "/health1",
|
||||||
|
Interval: 15000000000,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
||||||
|
},
|
||||||
|
TLS: &dynamic.TLSConfiguration{},
|
||||||
|
},
|
||||||
|
},
|
||||||
{
|
{
|
||||||
desc: "services lb, servers lb, and mirror service, all in a wrr with different namespaces",
|
desc: "services lb, servers lb, and mirror service, all in a wrr with different namespaces",
|
||||||
allowCrossNamespace: true,
|
allowCrossNamespace: true,
|
||||||
|
|
|
@ -131,6 +131,8 @@ type LoadBalancerSpec struct {
|
||||||
// It allows services to be reachable when Traefik runs externally from the Kubernetes cluster but within the same network of the nodes.
|
// It allows services to be reachable when Traefik runs externally from the Kubernetes cluster but within the same network of the nodes.
|
||||||
// By default, NodePortLB is false.
|
// By default, NodePortLB is false.
|
||||||
NodePortLB bool `json:"nodePortLB,omitempty"`
|
NodePortLB bool `json:"nodePortLB,omitempty"`
|
||||||
|
// Healthcheck defines health checks for the service.
|
||||||
|
HealthCheck *dynamic.ServerHealthCheck `json:"healthCheck,omitempty"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type ResponseForwarding struct {
|
type ResponseForwarding struct {
|
||||||
|
|
|
@ -582,6 +582,11 @@ func (in *LoadBalancerSpec) DeepCopyInto(out *LoadBalancerSpec) {
|
||||||
*out = new(bool)
|
*out = new(bool)
|
||||||
**out = **in
|
**out = **in
|
||||||
}
|
}
|
||||||
|
if in.HealthCheck != nil {
|
||||||
|
in, out := &in.HealthCheck, &out.HealthCheck
|
||||||
|
*out = new(dynamic.ServerHealthCheck)
|
||||||
|
(*in).DeepCopyInto(*out)
|
||||||
|
}
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue