Kubernetes no es específico de ningún proveedor; sin embargo, a fin de proporcionar instrucciones explícitas y completas para implementar todos los elementos de una implementación multi-clúster de un operador de Kubernetes, esta sección lo guiará mediante el proceso de implementación de múltiples clústeres de Kubernetes en GCP specifically.
Requisitos previos
Antes de comenzar, realice las siguientes acciones:
Crea una cuenta de GCP.
Prepare un proyecto de GCP para que pueda usarlo para crear GKE (Google Kubernetes Engine) clústeres.
Instala GCP CLI.
Autenticarse con el
gcloud auth logindominio.Actualiza según sea necesario y configura las variables de entorno definidas en el siguiente archivo
env_variables.sh.
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"
Código fuente
Se puede encontrar todo el código fuente incluido en el repositorio de MongoDB Kubernetes operador.
Procedimiento
Crear clústeres de Kubernetes.
Crea tres clústeres de GKE (Google Kubernetes Engine):
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:-""}"
Almacene las credenciales en su kubeconfig.
Obtener credenciales y guardar contextos en el archivo kubeconfig actual. De forma predeterminada, este archivo se encuentra en el directorio ~/.kube/config y se referencia mediante el directorio $KUBECONFIG. variable de entorno.
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}"
Todos los comandos de kubectl hacen referencia a estos contextos usando las siguientes variables:
$K8S_CLUSTER_0_CONTEXT_NAME$K8S_CLUSTER_1_CONTEXT_NAME$K8S_CLUSTER_2_CONTEXT_NAME
Verifique que kubectl tenga acceso a los clústeres de Kubernetes.
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-68bf14632610a500070df2fa-19959 2 NAME STATUS ROLES AGE VERSION 3 gke-k8s-mdb-0-68bf146326-default-pool-bec39049-m9jg Ready <none> 30s v1.33.3-gke.1136000 4 gke-k8s-mdb-0-68bf146326-default-pool-bec39049-tb7l Ready <none> 30s v1.33.3-gke.1136000 5 gke-k8s-mdb-0-68bf146326-default-pool-bec39049-zw58 Ready <none> 32s v1.33.3-gke.1136000 6 7 Nodes in cluster gke_scratch-kubernetes-team_europe-central2-b_k8s-mdb-1-68bf14632610a500070df2fa-19959 8 NAME STATUS ROLES AGE VERSION 9 gke-k8s-mdb-1-68bf146326-default-pool-be17e55e-g2lx Ready <none> 2m8s v1.33.3-gke.1136000 10 gke-k8s-mdb-1-68bf146326-default-pool-be17e55e-gt9x Ready <none> 2m7s v1.33.3-gke.1136000 11 gke-k8s-mdb-1-68bf146326-default-pool-be17e55e-j65l Ready <none> 2m9s v1.33.3-gke.1136000 12 13 Nodes in cluster gke_scratch-kubernetes-team_europe-central2-c_k8s-mdb-2-68bf14632610a500070df2fa-19959 14 NAME STATUS ROLES AGE VERSION 15 gke-k8s-mdb-2-68bf146326-default-pool-a61ceb12-f0x0 Ready <none> 114s v1.33.3-gke.1136000