Kubernetes is not vendor specific; however, for the sake of providing explicit and complete instructions for deploying all elements of a multi-cluster Kubernetes Operator implementation, this section walks you through the process of deploying multiple Kubernetes clusters on GCP specifically.
Prerequisites
Before you begin, perform the following actions:
- Create a GCP account. 
- Prepare a GCP project so that you can use it to create GKE (Google Kubernetes Engine) clusters. 
- Install the GCP CLI. 
- Authenticate with the - gcloud auth logincommand.
- Update as needed and set the environment variables defined in the following - env_variables.shfile.
1 # GCP project name - this is the only parameter that is mandatory to change here 2 export MDB_GKE_PROJECT="${MDB_GKE_PROJECT:="### Set your GKE project name here ###"}" 3 4 # Adjust the values for each Kubernetes cluster in your deployment. 5 # The deployment script references the following variables to get values for each cluster. 6 export K8S_CLUSTER_0="k8s-mdb-0${K8S_CLUSTER_SUFFIX:-""}" 7 export K8S_CLUSTER_0_ZONE="europe-central2-a" 8 export K8S_CLUSTER_0_NUMBER_OF_NODES=3 9 export K8S_CLUSTER_0_MACHINE_TYPE="e2-standard-4" 10 export K8S_CLUSTER_0_CONTEXT_NAME="gke_${MDB_GKE_PROJECT}_${K8S_CLUSTER_0_ZONE}_${K8S_CLUSTER_0}" 11 12 export K8S_CLUSTER_1="k8s-mdb-1${K8S_CLUSTER_SUFFIX:-""}" 13 export K8S_CLUSTER_1_ZONE="europe-central2-b" 14 export K8S_CLUSTER_1_NUMBER_OF_NODES=3 15 export K8S_CLUSTER_1_MACHINE_TYPE="e2-standard-4" 16 export K8S_CLUSTER_1_CONTEXT_NAME="gke_${MDB_GKE_PROJECT}_${K8S_CLUSTER_1_ZONE}_${K8S_CLUSTER_1}" 17 18 export K8S_CLUSTER_2="k8s-mdb-2${K8S_CLUSTER_SUFFIX:-""}" 19 export K8S_CLUSTER_2_ZONE="europe-central2-c" 20 export K8S_CLUSTER_2_NUMBER_OF_NODES=1 21 export K8S_CLUSTER_2_MACHINE_TYPE="e2-standard-4" 22 export K8S_CLUSTER_2_CONTEXT_NAME="gke_${MDB_GKE_PROJECT}_${K8S_CLUSTER_2_ZONE}_${K8S_CLUSTER_2}" 23 24 # Comment out the following line so that the script does not create preemptible nodes. 25 # DO NOT USE preemptible nodes in production. 26 export GKE_SPOT_INSTANCES_SWITCH="--preemptible" 
Source Code
You can find all included source code in the MongoDB Kubernetes Operator repository.
Procedure
Create Kubernetes clusters.
Create three GKE (Google Kubernetes Engine) clusters:
1 gcloud container clusters create "${K8S_CLUSTER_0}" \ 2       --zone="${K8S_CLUSTER_0_ZONE}" \ 3       --num-nodes="${K8S_CLUSTER_0_NUMBER_OF_NODES}" \ 4       --machine-type "${K8S_CLUSTER_0_MACHINE_TYPE}" \ 5       --tags=mongodb \ 6       "${GKE_SPOT_INSTANCES_SWITCH:-""}" 
1 gcloud container clusters create "${K8S_CLUSTER_1}" \ 2       --zone="${K8S_CLUSTER_1_ZONE}" \ 3       --num-nodes="${K8S_CLUSTER_1_NUMBER_OF_NODES}" \ 4       --machine-type "${K8S_CLUSTER_1_MACHINE_TYPE}" \ 5       --tags=mongodb \ 6       "${GKE_SPOT_INSTANCES_SWITCH:-""}" 
1 gcloud container clusters create "${K8S_CLUSTER_2}" \ 2       --zone="${K8S_CLUSTER_2_ZONE}" \ 3       --num-nodes="${K8S_CLUSTER_2_NUMBER_OF_NODES}" \ 4       --machine-type "${K8S_CLUSTER_2_MACHINE_TYPE}" \ 5       --tags=mongodb \ 6       "${GKE_SPOT_INSTANCES_SWITCH:-""}" 
Store credentials in your kubeconfig.
Obtain credentials and save contexts to the current kubeconfig
file. By default, this file is located in the ~/.kube/config directory
and referenced by the $KUBECONFIG environment variable.
1 gcloud container clusters get-credentials "${K8S_CLUSTER_0}" --zone="${K8S_CLUSTER_0_ZONE}" 2 gcloud container clusters get-credentials "${K8S_CLUSTER_1}" --zone="${K8S_CLUSTER_1_ZONE}" 3 gcloud container clusters get-credentials "${K8S_CLUSTER_2}" --zone="${K8S_CLUSTER_2_ZONE}" 
All kubectl commands reference these contexts using the following variables:
- $K8S_CLUSTER_0_CONTEXT_NAME
- $K8S_CLUSTER_1_CONTEXT_NAME
- $K8S_CLUSTER_2_CONTEXT_NAME
Verify that kubectl has access to Kubernetes clusters.
1 echo "Nodes in cluster ${K8S_CLUSTER_0_CONTEXT_NAME}" 2 kubectl --context "${K8S_CLUSTER_0_CONTEXT_NAME}" get nodes 3 echo; echo "Nodes in cluster ${K8S_CLUSTER_1_CONTEXT_NAME}" 4 kubectl --context "${K8S_CLUSTER_1_CONTEXT_NAME}" get nodes 5 echo; echo "Nodes in cluster ${K8S_CLUSTER_2_CONTEXT_NAME}" 6 kubectl --context "${K8S_CLUSTER_2_CONTEXT_NAME}" get nodes 
1 Nodes in cluster gke_scratch-kubernetes-team_europe-central2-a_k8s-mdb-0-682f2df6e1745e000788a1d5-19985 2 NAME                                                  STATUS   ROLES    AGE     VERSION 3 gke-k8s-mdb-0-682f2df6e1-default-pool-68d97b7f-fct9   Ready    <none>   2m20s   v1.32.3-gke.1785003 4 gke-k8s-mdb-0-682f2df6e1-default-pool-68d97b7f-k9td   Ready    <none>   2m20s   v1.32.3-gke.1785003 5 gke-k8s-mdb-0-682f2df6e1-default-pool-68d97b7f-pwsw   Ready    <none>   2m19s   v1.32.3-gke.1785003 6 7 Nodes in cluster gke_scratch-kubernetes-team_europe-central2-b_k8s-mdb-1-682f2df6e1745e000788a1d5-19985 8 NAME                                                  STATUS   ROLES    AGE   VERSION 9 gke-k8s-mdb-1-682f2df6e1-default-pool-0f84fbc8-1b4j   Ready    <none>   32s   v1.32.3-gke.1785003 10 gke-k8s-mdb-1-682f2df6e1-default-pool-0f84fbc8-fn7x   Ready    <none>   32s   v1.32.3-gke.1785003 11 gke-k8s-mdb-1-682f2df6e1-default-pool-0f84fbc8-k4hc   Ready    <none>   32s   v1.32.3-gke.1785003 12 13 Nodes in cluster gke_scratch-kubernetes-team_europe-central2-c_k8s-mdb-2-682f2df6e1745e000788a1d5-19985 14 NAME                                                  STATUS   ROLES    AGE    VERSION 15 gke-k8s-mdb-2-682f2df6e1-default-pool-ff13f41c-m4f9   Ready    <none>   4m6s   v1.32.3-gke.1785003