En este documento, se muestra un ejemplo de cómo configurar un clúster de Google Distributed Cloud para que use la afinidad de VM-host.
La afinidad del grupo de host-VM es uno de los mecanismos que proporciona Google Distributed Cloud para garantizar la alta disponibilidad. Con la afinidad de grupos de VM-host, creas grupos de hosts ESXi físicos. Luego, configura tu clúster para asociar los grupos de VMs con los grupos de hosts.
Por ejemplo, puedes configurar todas las VMs de un grupo de nodos para que se ejecuten en un grupo de hosts particular. También puedes configurar todas las VMs de un segundo grupo de nodos para que se ejecuten en un grupo de host diferente. Luego, puedes tratar cada grupo de nodos como un dominio con fallas. Para diferenciar los dominios de fallas, puedes agregar etiquetas a las VMs de los diferentes grupos de nodos.
Antes de comenzar
Para este ejercicio, debes tener al menos seis hosts ESXi en tu entorno de vSphere.
Cómo crear grupos de hosts
Crea dos o más grupos de DRS de host en tu entorno de vSphere. Para este ejercicio, lo más adecuado sería usar dos grupos de hosts con tres hosts cada uno. Para obtener instrucciones, consulta Cómo crear un grupo de DRS de host.
Crea un clúster de usuario
En esta sección, se muestra un ejemplo de cómo crear un clúster de usuarios que usa la afinidad del grupo de VM-Host. El clúster de este ejemplo usa Controlplane V2. El clúster tiene un plano de control de alta disponibilidad, por lo que hay tres nodos de plano de control. Además de los nodos del plano de control, hay seis nodos trabajadores: tres en un grupo de nodos y tres en un segundo grupo de nodos. Todos los nodos usan direcciones IP estáticas.
Comienza por seguir las instrucciones en Crea un clúster de usuario (Controlplane V2).
Cuando completes el archivo de configuración del clúster de usuario, haz lo siguiente:
- Especifica dos grupos de nodos para los nodos trabajadores. Para cada grupo de nodos, establece
replicas
en3
y proporciona el nombre de un grupo de host existente.
Archivo de configuración de ejemplo
Este es un ejemplo de un archivo de bloque de IP y una parte de un archivo de configuración de clúster de usuario.
user-ipblock.yaml
blocks: - netmask: 255.255.255.0 gateway: 172.16.21.1 ips: - ip: 172.16.21.2 - ip: 172.16.21.3 - ip: 172.16.21.4 - ip: 172.16.21.5 - ip: 172.16.21.6 - ip: 172.16.21.7 - ip: 172.16.21.8
user-cluster-yaml
apiVersion: v1 kind: UserCluster ... network: hostConfig: dnsServers: - "203.0.113.2" - "198.51.100.2" ntpServers: - "216.239.35.4" ipMode: type: "static" ipBlockFilePath: "user-ipblock.yaml" controlPlaneIPBlock: netmask: "255.255.255.0" gateway: "172.16.21.1" ips: - ip: "172.16.21.9" hostname: "cp-vm-1" - ip: "172.16.21.10" hostname: "cp-vm-2" - ip: "172.16.21.11" hostname: "cp-vm-3" loadBalancer: vips: controlPlaneVIP: "172.16.21.40" ingressVIP: "172.16.21.30" kind: MetalLB metalLB: addressPools: - name: "address-pool-1" addresses: - "172.16.21.30-172.16.21.39" ... enableControlplaneV2: true masterNode: cpus: 4 memoryMB: 8192 replicas: 3 nodePools: - name: "worker-pool-1" enableLoadBalancer: true replicas: 3 vsphere: hostgroups: - "hostgroup-1" labels: failuredomain: "failuredomain-1" - name: "worker-pool-2" replicas: 3 vsphere: hostgroups: - "hostgroup-2" labels: failuredomain: "failuredomain-2" ...
Estos son los puntos importantes que debes comprender en el ejemplo anterior:
Las direcciones IP estáticas de los nodos trabajadores se especifican en un archivo de bloque de IP. El archivo de bloque de IP tiene siete direcciones, aunque solo hay seis nodos de trabajo. La dirección IP adicional es necesaria durante las actualizaciones y la reparación automática del clúster.
Las direcciones IP estáticas de los tres nodos del plano de control se especifican en la sección
network.controlPlaneIPBlock
del archivo de configuración del clúster de usuarios. No es necesario tener una dirección IP adicional en este bloque.El campo
masterNode.replicas
está configurado como3
, por lo que habrá tres nodos de plano de control.Un controlador de clúster creará un grupo de DRS de VM que tenga los tres nodos del grupo de nodos
worker-pool-1
. Un controlador también creará una regla de afinidad de VM a host que garantice que los nodos deworker-pool-1
se ejecuten en hosts que se encuentren enhostgroup-1
. Los nodos deworker-pool-1
tienen la etiquetafailuredomain: "failuredomain-1"
.Un controlador de clúster creará un grupo de DRS de VM que tenga los tres nodos del grupo de nodos
worker-pool-2
. Un controlador también creará una regla de afinidad de VM a host que garantice que los nodos enworker-pool-2
se ejecuten en hosts que se encuentran enhostgroup-2
. Los nodos deworker-pool-2
tienen la etiquetafailuredomain: "failuredomain-2"
.
Continúa creando tu clúster de usuario, como se describe en Crea un clúster de usuario (Controlplane V2).