mirror of https://github.com/hashicorp/consul
docs: Ingress controllers configurations (#10495)
Add high level documentation on how to enable ingress controllers in consul on k8s. Co-authored-by: Blake Covarrubias <blake@covarrubi.as> Co-authored-by: Luke Kysow <1034429+lkysow@users.noreply.github.com>pull/10765/head
parent
61283c85a6
commit
152dc1b04b
|
@ -243,8 +243,8 @@ Pod annotations can be used to configure the injection behavior.
|
|||
list of inbound ports to exclude from traffic redirection when running in transparent proxy
|
||||
mode.
|
||||
|
||||
- `consul.hashicorp.com/transparent-proxy-exclude-inbound-cidrs` - A comma-separated
|
||||
list of inbound CIDRs to exclude from traffic redirection when running in transparent proxy
|
||||
- `consul.hashicorp.com/transparent-proxy-exclude-outbound-cidrs` - A comma-separated
|
||||
list of outbound CIDRs to exclude from traffic redirection when running in transparent proxy
|
||||
mode.
|
||||
|
||||
- `consul.hashicorp.com/transparent-proxy-exclude-outbound-ports` - A comma-separated
|
||||
|
|
|
@ -0,0 +1,94 @@
|
|||
---
|
||||
layout: docs
|
||||
page_title: Ingress Controller Integrations
|
||||
description: Configuring Ingress Controllers With Consul On Kubernetes
|
||||
---
|
||||
|
||||
# Configuring Ingress Controllers with Consul on Kubernetes
|
||||
|
||||
-> This topic requires familiarity with [Ingress Controllers](https://kubernetes.io/docs/concepts/services-networking/ingress-controllers/)
|
||||
|
||||
-> The following information requires Consul 1.10+, Consul-k8s 0.26+, Consul-helm 0.32+ configured with
|
||||
[Transparent Proxy](/docs/connect/transparent-proxy) mode enabled.
|
||||
|
||||
This page describes a general approach for integrating Ingress Controllers with Consul on Kubernetes to secure traffic from the Controller
|
||||
to the backend services. This allows Consul to transparently secure traffic from the ingress point through the entire traffic flow of the service.
|
||||
|
||||
A few steps are generally required to enable an Ingress controller to join the mesh and pass traffic through to a service:
|
||||
|
||||
* Enable connect-injection via an annotation on the Ingress Controller's deployment: `consul.hashicorp.com/connect-inject` is `true`.
|
||||
|
||||
* Using the following annotations on the Ingress controller's deployment, set up exclusion rules for its ports.
|
||||
* [`consul.hashicorp.com/transparent-proxy-exclude-inbound-ports`](/docs/k8s/connect#consul-hashicorp-com-transparent-proxy-exclude-inbound-ports) - Provides the ability to exclude a list of ports for
|
||||
inbound traffic that the service exposes from redirection. Typical configurations would require all inbound service ports
|
||||
for the controller to be included in this list.
|
||||
* [`consul.hashicorp.com/transparent-proxy-exclude-outbound-ports`](/docs/k8s/connect#consul-hashicorp-com-transparent-proxy-exclude-outbound-ports) - Provides the ability to exclude a list of ports for
|
||||
outbound traffic that the service exposes from redirection. These would be outbound ports used by your ingress controller
|
||||
which expect to skip the mesh and talk to non-mesh services.
|
||||
* [`consul.hashicorp.com/transparent-proxy-exclude-outbound-cidrs`](/docs/k8s/connect#consul-hashicorp-com-transparent-proxy-exclude-outbound-cidrs) - Provides the ability to exclude a list of CIDRs that
|
||||
the service communicates with for outbound requests from redirection. It is somewhat common that an Ingress controller
|
||||
will expect to make API calls to the Kubernetes service for service/endpoint management. As such including the ClusterIP of the
|
||||
Kubernetes service is common.
|
||||
|
||||
~> Note: Depending on which ingress controller you use, these stanzas may differ in name and layout, but it is important to apply
|
||||
these annotations to the *pods* of your *ingress controller*.
|
||||
```yaml
|
||||
# An example list of pod annotations for an ingress controller, which need be applied to PODS for the controller, not the deployment itself.
|
||||
podAnnotations:
|
||||
consul.hashicorp.com/connect-inject: "true"
|
||||
# Add the container ports used by your ingress controller
|
||||
consul.hashicorp.com/transparent-proxy-exclude-inbound-ports: "80,8000,9000,8443"
|
||||
# And the CIDR of your Kubernetes API: `kubectl get svc kubernetes -o jsonpath='{.spec.clusterIP}'
|
||||
consul.hashicorp.com/transparent-proxy-exclude-outbound-cidrs: "10.108.0.1/32"
|
||||
```
|
||||
|
||||
* If the Ingress controller acts as a LoadBalancer and routes directly to Pod IPs instead of the ClusterIP of your Kubernetes Services
|
||||
a `ServiceDefault` CRD must be applied to *each backend service* allowing it to use the `dialedDirectly` features. By default this is disabled.
|
||||
|
||||
```yaml
|
||||
# Example Service defaults config entry
|
||||
apiVersion: consul.hashicorp.com/v1alpha1
|
||||
kind: ServiceDefaults
|
||||
metadata:
|
||||
name: backend
|
||||
spec:
|
||||
transparentProxy:
|
||||
dialedDirectly: true
|
||||
```
|
||||
|
||||
* An intention from the Ingress Controller to the backend application must also be applied, this could be an L4 or L7 intention:
|
||||
|
||||
```yaml
|
||||
# example L4 intention, but an L7 intention can also be used to control access to specific routes.
|
||||
apiVersion: consul.hashicorp.com/v1alpha1
|
||||
kind: ServiceIntentions
|
||||
metadata:
|
||||
name: ingress-backend
|
||||
spec:
|
||||
destination:
|
||||
name: backend
|
||||
sources:
|
||||
- name: ingress
|
||||
action: allow
|
||||
```
|
||||
|
||||
### Common Configuration Problems:
|
||||
- The Ingress Controller's ServiceAccount name and Service name differ by default in some platforms. Consul on Kubernetes requires the
|
||||
ServiceAccount and Service to have the same name. To resolve this be sure to explicitly set ServiceAccount name the same as the ingress
|
||||
controller service name using it's respective helm configurations.
|
||||
|
||||
- If the Ingress Controller does not have the correct inbound ports excluded it will fail to start and the Ingress'
|
||||
service will not get created, causing the controller to hang in the init container. The required container ports are not
|
||||
always readily available in the helm charts, so in order to resolve this examine the ingress controller's
|
||||
underlying pod spec and look for the required container ports, adding these to the `consul.hashicorp.com/transparent-proxy-exclude-inbound-ports`
|
||||
annotation on the ingress controller deployment.
|
||||
|
||||
### Examples:
|
||||
Here are a couple example configurations which can be used as reference points in setting up your own ingress controller configuration!
|
||||
These were used in dev environments and are not intended to be fully supported but should provide some idea how to extend the information
|
||||
above to your own uses cases.
|
||||
|
||||
~> https://github.com/kschoche/traefik-consul
|
||||
|
||||
~> https://github.com/joatmon08/consul-k8s-ingress-controllers
|
||||
|
|
@ -454,6 +454,10 @@
|
|||
"title": "Terminating Gateways",
|
||||
"path": "k8s/connect/terminating-gateways"
|
||||
},
|
||||
{
|
||||
"title": "Ingress Controllers",
|
||||
"path": "k8s/connect/ingress-controllers"
|
||||
},
|
||||
{
|
||||
"title": "Configuring a Connect CA Provider",
|
||||
"path": "k8s/connect/connect-ca-provider"
|
||||
|
|
Loading…
Reference in New Issue