mirror of https://github.com/hashicorp/consul
Updates to fed docs for 0.43.0 (#13026)
* Updates to fed docs for 0.43.0 * Fix docs for VMs and for auth methodpull/13036/head
parent
4a2b61a1f4
commit
24e573edc8
|
@ -64,6 +64,9 @@ mesh gateway, the load balancer IP must be routable from the other mesh gateway
|
|||
If using a public load balancer, this is guaranteed. If using a private load balancer
|
||||
then you'll need to make sure that its IP is routable from your other clusters.
|
||||
|
||||
In addition, if ACLs are enabled, primary clusters must be able to make requests to the Kubernetes API URL of
|
||||
secondary clusters.
|
||||
|
||||
## Next Steps
|
||||
|
||||
Now that you have an overview of federation, proceed to either the
|
||||
|
|
|
@ -62,8 +62,7 @@ global:
|
|||
# Gossip encryption secures the protocol Consul uses to quickly
|
||||
# discover new nodes and detect failure.
|
||||
gossipEncryption:
|
||||
secretName: consul-gossip-encryption-key
|
||||
secretKey: key
|
||||
autoGenerate: true
|
||||
|
||||
connectInject:
|
||||
# Consul Connect service mesh must be enabled for federation.
|
||||
|
@ -103,19 +102,13 @@ Modifications:
|
|||
```yaml
|
||||
global:
|
||||
# gossipEncryption:
|
||||
# secretName: consul-gossip-encryption-key
|
||||
# secretKey: key
|
||||
# autoGenerate: true
|
||||
```
|
||||
|
||||
Gossip encryption encrypts the communication layer used to discover other
|
||||
nodes in the cluster and report on failure. If you are only testing Consul,
|
||||
this is not required.
|
||||
|
||||
**NOTE:** This config assumes you've already
|
||||
created a Kubernetes secret called `consul-gossip-encryption-key`. See
|
||||
[the docs for this setting](/docs/k8s/helm#v-global-gossipencryption) for
|
||||
more information on how to create this secret.
|
||||
|
||||
1. The default mesh gateway configuration
|
||||
creates a Kubernetes Load Balancer service. If you wish to customize the
|
||||
mesh gateway, for example using a Node Port service or a custom DNS entry,
|
||||
|
@ -224,7 +217,7 @@ After the installation into your primary cluster you will need to export
|
|||
this secret:
|
||||
|
||||
```shell-session
|
||||
$ kubectl get secret consul-federation --output yaml > consul-federation-secret.yaml
|
||||
$ kubectl get secret consul-federation --namespace consul --output yaml > consul-federation-secret.yaml
|
||||
```
|
||||
|
||||
!> **Security note:** The federation secret makes it possible to gain
|
||||
|
@ -234,7 +227,8 @@ cluster and you should use RBAC permissions to ensure only administrators
|
|||
can read it from Kubernetes.
|
||||
|
||||
~> **Secret doesn't exist?** If you haven't set `global.name` to `consul` then the name of the secret will
|
||||
be your Helm release name suffixed with `-consul-federation` e.g. `helm-release-consul-federation`.
|
||||
be your Helm release name suffixed with `-consul-federation` e.g. `helm-release-consul-federation`. Also ensure you're
|
||||
using the namespace Consul was installed into.
|
||||
|
||||
Now you're ready to import the secret into your secondary cluster(s).
|
||||
|
||||
|
@ -293,6 +287,30 @@ The automatically generated federation secret contains:
|
|||
!> **Security note:** This gossip encryption key would enable an attacker to compromise Consul,
|
||||
it should be kept securely.
|
||||
|
||||
## Kubernetes API URL
|
||||
|
||||
If ACLs are enabled, you must next determine the Kubernetes API URL for the secondary cluster. The API URL of the
|
||||
must be specified in the config files for all secondary clusters because secondary clusters need
|
||||
to create global Consul ACL tokens (tokens that are valid in all datacenters) and these tokens can only be created
|
||||
by the primary datacenter. By setting the API URL, the secondary cluster will configure a [Consul auth method](/docs/security/acl/auth-methods)
|
||||
in the primary cluster so that components in the secondary cluster can use their Kubernetes ServiceAccount tokens
|
||||
to retrieve global Consul ACL tokens from the primary.
|
||||
|
||||
To determine the Kubernetes API URL, first get the cluster name in your kubeconfig:
|
||||
|
||||
```shell-session
|
||||
$ export CLUSTER=$(kubectl config view -o jsonpath="{.contexts[?(@.name == \"$(kubectl config current-context)\")].context.cluster}")
|
||||
```
|
||||
|
||||
Then get the API URL:
|
||||
|
||||
```shell-session
|
||||
$ kubectl config view -o jsonpath="{.clusters[?(@.name == \"$CLUSTER\")].cluster.server}"
|
||||
https://<some-url>
|
||||
```
|
||||
|
||||
Keep track of this URL, you'll need it in the next section.
|
||||
|
||||
## Secondary Cluster(s)
|
||||
|
||||
With the primary cluster up and running, and the [federation secret](#federation-secret) imported
|
||||
|
@ -300,7 +318,7 @@ into the secondary cluster, we can now install Consul into the secondary
|
|||
cluster.
|
||||
|
||||
You will need to use the following `config.yaml` file for your secondary cluster(s),
|
||||
with the possible modifications listed below.
|
||||
with the modifications listed below.
|
||||
|
||||
-> **NOTE: ** You must use a separate Helm config file for each cluster (primary and secondaries) since their
|
||||
settings are different.
|
||||
|
@ -334,6 +352,8 @@ global:
|
|||
|
||||
federation:
|
||||
enabled: true
|
||||
k8sAuthMethodHost: <kubernetes-api-url>
|
||||
primaryDatacenter: dc1
|
||||
gossipEncryption:
|
||||
secretName: consul-federation
|
||||
secretKey: gossipEncryptionKey
|
||||
|
@ -360,8 +380,10 @@ server:
|
|||
|
||||
Modifications:
|
||||
|
||||
1. The Consul datacenter name is `dc2`. The primary datacenter's name was `dc1`.
|
||||
The datacenter name in **each** federated cluster **must be unique**.
|
||||
1. If ACLs are enabled, change the value of `global.federation.k8sAuthMethodHost` to the full URL (including `https://`) of this cluster's
|
||||
Kubernetes API.
|
||||
1. `global.federation.primaryDatacenter` must be set to the name of the primary datacenter.
|
||||
1. The Consul datacenter name for the datacenter in this example is `dc2`. The datacenter name in **each** federated cluster **must be unique**.
|
||||
1. ACLs are enabled in the above config file. They can be disabled by removing
|
||||
the whole `acls` block:
|
||||
|
||||
|
@ -403,7 +425,7 @@ To verify that both datacenters are federated, run the
|
|||
`consul members -wan` command on one of the Consul server pods:
|
||||
|
||||
```shell-session
|
||||
$ kubectl exec statefulset/consul-server -- consul members -wan
|
||||
$ kubectl exec statefulset/consul-server --namespace consul -- consul members -wan
|
||||
Node Address Status Type Build Protocol DC Segment
|
||||
consul-server-0.dc1 10.32.4.216:8302 alive server 1.8.0 2 dc1 <all>
|
||||
consul-server-0.dc2 192.168.2.173:8302 alive server 1.8.0 2 dc2 <all>
|
||||
|
@ -421,7 +443,7 @@ each datacenter can read each other's services. In this example, our `kubectl`
|
|||
context is `dc1` and we're querying for the list of services in `dc2`:
|
||||
|
||||
```shell-session
|
||||
$ kubectl exec statefulset/consul-server -- consul catalog services -datacenter dc2
|
||||
$ kubectl exec statefulset/consul-server --namespace consul -- consul catalog services -datacenter dc2
|
||||
consul
|
||||
mesh-gateway
|
||||
```
|
||||
|
|
|
@ -35,13 +35,13 @@ The following sections detail how to export this data.
|
|||
1. Retrieve the certificate authority cert:
|
||||
|
||||
```sh
|
||||
kubectl get secrets/consul-ca-cert --template='{{index .data "tls.crt" | base64decode }}' > consul-agent-ca.pem
|
||||
kubectl get secrets/consul-ca-cert --namespace consul --template='{{index .data "tls.crt" | base64decode }}' > consul-agent-ca.pem
|
||||
```
|
||||
|
||||
1. And the certificate authority signing key:
|
||||
|
||||
```sh
|
||||
kubectl get secrets/consul-ca-key --template='{{index .data "tls.key" | base64decode }}' > consul-agent-ca-key.pem
|
||||
kubectl get secrets/consul-ca-key --namespace consul --template='{{index .data "tls.key" | base64decode }}' > consul-agent-ca-key.pem
|
||||
```
|
||||
|
||||
1. With the `consul-agent-ca.pem` and `consul-agent-ca-key.pem` files you can
|
||||
|
@ -102,7 +102,7 @@ The following sections detail how to export this data.
|
|||
Retrieve the WAN addresses of the mesh gateways:
|
||||
|
||||
```shell-session
|
||||
$ kubectl exec statefulset/consul-server -- sh -c \
|
||||
$ kubectl exec statefulset/consul-server --namespace consul -- sh -c \
|
||||
'curl --silent --insecure https://localhost:8501/v1/catalog/service/mesh-gateway | jq ".[].ServiceTaggedAddresses.wan"'
|
||||
{
|
||||
"Address": "1.2.3.4",
|
||||
|
@ -129,7 +129,7 @@ primary_gateways = ["1.2.3.4:443"]
|
|||
If ACLs are enabled, you'll also need the replication ACL token:
|
||||
|
||||
```shell-session
|
||||
$ kubectl get secrets/consul-acl-replication-acl-token --template='{{.data.token | base64decode}}'
|
||||
$ kubectl get secrets/consul-acl-replication-acl-token --namespace consul --template='{{.data.token | base64decode}}'
|
||||
e7924dd1-dc3f-f644-da54-81a73ba0a178
|
||||
```
|
||||
|
||||
|
@ -273,6 +273,28 @@ kubectl create secret generic consul-federation \
|
|||
# --from-literal=gossipEncryptionKey="<your gossip encryption key>"
|
||||
```
|
||||
|
||||
If ACLs are enabled, you must next determine the Kubernetes API URL for the secondary cluster. The API URL of the
|
||||
must be specified in the config files for all secondary clusters because secondary clusters need
|
||||
to create global Consul ACL tokens (tokens that are valid in all datacenters) and these tokens can only be created
|
||||
by the primary datacenter. By setting the API URL, the secondary cluster will configure a [Consul auth method](/docs/security/acl/auth-methods)
|
||||
in the primary cluster so that components in the secondary cluster can use their Kubernetes ServiceAccount tokens
|
||||
to retrieve global Consul ACL tokens from the primary.
|
||||
|
||||
To determine the Kubernetes API URL, first get the cluster name in your kubeconfig:
|
||||
|
||||
```shell-session
|
||||
$ export CLUSTER=$(kubectl config view -o jsonpath="{.contexts[?(@.name == \"$(kubectl config current-context)\")].context.cluster}")
|
||||
```
|
||||
|
||||
Then get the API URL:
|
||||
|
||||
```shell-session
|
||||
$ kubectl config view -o jsonpath="{.clusters[?(@.name == \"$CLUSTER\")].cluster.server}"
|
||||
https://<some-url>
|
||||
```
|
||||
|
||||
You'll use this URL when setting `global.federation.k8sAuthMethodHost`.
|
||||
|
||||
Then use the following Helm config file:
|
||||
|
||||
```yaml
|
||||
|
@ -297,6 +319,8 @@ global:
|
|||
|
||||
federation:
|
||||
enabled: true
|
||||
k8sAuthMethodHost: <kubernetes-api-url>
|
||||
primaryDatacenter: dc1
|
||||
|
||||
# Delete this gossipEncryption section if gossip encryption is disabled.
|
||||
gossipEncryption:
|
||||
|
@ -312,14 +336,16 @@ meshGateway:
|
|||
server:
|
||||
extraConfig: |
|
||||
{
|
||||
"primary_datacenter": "<your VM datacenter name>",
|
||||
"primary_gateways": ["<ip of your VM mesh gateway>", "<other ip>", ...]
|
||||
}
|
||||
```
|
||||
|
||||
-> **NOTE: ** You must fill out the `server.extraConfig` section with the datacenter
|
||||
name of your primary datacenter running on VMs and with the IPs of your mesh
|
||||
Notes:
|
||||
|
||||
1. You must fill out the `server.extraConfig` section with the IPs of your mesh
|
||||
gateways running on VMs.
|
||||
1. Set `global.federation.k8sAuthMethodHost` to the Kubernetes API URL of this cluster (including `https://`).
|
||||
1. `global.federation.primaryDatacenter` should be set to the name of your primary datacenter.
|
||||
|
||||
With your config file ready to go, follow our [Installation Guide](/docs/k8s/installation/install)
|
||||
to install Consul on your secondary cluster(s).
|
||||
|
|
Loading…
Reference in New Issue