Cuando creas un clúster de Kubernetes aislado de Google Distributed Cloud (GDC), la cantidad y el tipo de nodos que especificas crean el primer grupo de nodos del clúster. Puedes realizar las siguientes tareas del grupo de nodos para un clúster existente a medida que cambian sus requisitos de procesamiento:
Agregar un grupo de nodos nuevo: Agrega grupos de nodos nuevos a medida que aumenta la demanda de las cargas de trabajo de tu clúster.
Ver un grupo de nodos: Consulta las características y el estado de tus grupos de nodos existentes.
Cambiar el tamaño de un grupo de nodos: Aumenta o disminuye de forma manual tus grupos de nodos para adaptarlos a las fluctuaciones del tráfico de la carga de trabajo.
Borrar un grupo de nodos: Quita los grupos de nodos si disminuye la demanda de las cargas de trabajo de tu clúster o si deseas borrar tipos de máquinas que ya no son prudentes para tus operaciones de contenedores.
Para obtener más información sobre los grupos de nodos en un clúster, consulta Acerca de los nodos.
Este documento está dirigido a desarrolladores de aplicaciones dentro del grupo de operadores de aplicaciones y administradores de TI dentro del grupo de administradores de la plataforma que son responsables de administrar clústeres de Kubernetes dentro de su organización. Para obtener más información, consulta Públicos de la documentación de Google Distributed Cloud aislado.
Antes de comenzar
Para completar las tareas de este documento, debes tener los siguientes recursos y roles:
Para ver y administrar grupos de nodos en un clúster de Kubernetes compartido, pídele a tu administrador de IAM de la organización que te otorgue los siguientes roles:
- Administrador de clústeres de usuario (
user-cluster-admin) - Visualizador de nodos de clústeres de usuario (
user-cluster-node-viewer)
Estos roles no están vinculados a un espacio de nombres.
- Administrador de clústeres de usuario (
Para ver y administrar grupos de nodos en un clúster de Kubernetes estándar, pídele a tu administrador de IAM de la organización que te otorgue el rol de administrador de clústeres estándar (
standard-cluster-admin). Este rol está vinculado al espacio de nombres de tu proyecto.Para ejecutar comandos en un clúster de Kubernetes, asegúrate de tener los siguientes recursos:
Ubica el nombre del clúster de Kubernetes o pregúntale a un miembro del grupo de administradores de la plataforma cuál es el nombre del clúster.
Accede y genera el archivo kubeconfig para el clúster de Kubernetes si no tienes uno.
Usa la ruta de acceso kubeconfig del clúster de Kubernetes para reemplazar
KUBERNETES_CLUSTER_KUBECONFIGen estas instrucciones.
Agrega un grupo de nodos
Para agregar un grupo de nodos a un clúster de Kubernetes existente, completa los siguientes pasos:
Console
- En el menú de navegación, selecciona Kubernetes Engine > Clústeres.
- Haz clic en el clúster de la lista de clústeres. Aparecerá la página Detalles del clúster.
- Selecciona Grupos de nodos > Agregar grupo de nodos.
- Asigna un nombre al grupo de nodos. No puedes modificar el nombre después de crear el grupo de nodos.
- Especifica la cantidad de nodos trabajadores que se crearán en el grupo de nodos.
- Selecciona la clase de máquina que mejor se adapte a los requisitos de tu carga de trabajo. Las clases de máquinas se muestran en la siguiente configuración:
- Tipo de máquina
- vCPU
- Memoria
- Haz clic en Guardar.
API
Abre la especificación de recursos personalizados
Clustercon la CLI dekubectlmediante el editor interactivo:kubectl edit clusters.cluster.gdc.goog/KUBERNETES_CLUSTER_NAME \ -n KUBERNETES_CLUSTER_NAMESPACE \ --kubeconfig MANAGEMENT_API_SERVERReemplaza lo siguiente:
KUBERNETES_CLUSTER_NAME: el nombre del clúster.KUBERNETES_CLUSTER_NAMESPACE: el espacio de nombres del clúster. Para los clústeres compartidos, usa el espacio de nombresplatform. Para los clústeres estándar, usa el espacio de nombres del proyecto del clúster.MANAGEMENT_API_SERVER: la ruta de acceso kubeconfig del servidor de la API zonal en la que se aloja el clúster de Kubernetes. Si aún no generaste un archivo kubeconfig para el servidor de la API en tu zona objetivo, consulta Accede para obtener más detalles.
Agrega una entrada nueva en la sección
nodePools:nodePools: # Several lines of code are omitted here. - machineTypeName: MACHINE_TYPE name: NODE_POOL_NAME nodeCount: NUMBER_OF_WORKER_NODES taints: TAINTS labels: LABELS acceleratorOptions: gpuPartitionScheme: GPU_PARTITION_SCHEMEReemplaza lo siguiente:
MACHINE_TYPE: el tipo de máquina para los nodos trabajadores del grupo de nodos. Consulta los tipos de máquinas disponibles para ver lo que está disponible para configurar.NODE_POOL_NAME: el nombre del grupo de nodos.NUMBER_OF_WORKER_NODES: la cantidad de nodos trabajadores que se aprovisionarán en el grupo de nodos.TAINTS: los taints que se aplicarán a los nodos de este grupo de nodos. Este paso es opcional,LABELS: las etiquetas que se aplicarán a los nodos de este grupo de nodos. Contiene una lista de pares clave-valor. Este paso es opcional,GPU_PARTITION_SCHEME: el esquema de partición de GPU, si ejecutas cargas de trabajo de GPU. Por ejemplo,mixed-2. La GPU no se particiona si no se configura este campo. Para obtener perfiles de GPU de instancias múltiples (MIG) disponibles, consulta Perfiles de MIG compatibles.
Guarda el archivo y sal del editor.
Visualiza grupos de nodos
Para ver los grupos de nodos existentes en un clúster de Kubernetes, completa los siguientes pasos:
Console
- En el menú de navegación, selecciona Kubernetes Engine > Clústeres.
- Haz clic en el clúster de la lista de clústeres. Aparecerá la página Detalles del clúster.
- Selecciona Grupos de nodos.
Se muestra la lista de grupos de nodos que se ejecutan en el clúster. Puedes administrar los grupos de nodos del clúster desde esta página.
API
Visualiza los grupos de nodos de un clúster de Kubernetes específico:
kubectl get clusters.cluster.gdc.goog/KUBERNETES_CLUSTER_NAME \ -n KUBERNETES_CLUSTER_NAMESPACE \ -o json --kubeconfig MANAGEMENT_API_SERVER | \ jq .status.workerNodePoolStatusesReemplaza lo siguiente:
KUBERNETES_CLUSTER_NAME: el nombre del clúster.KUBERNETES_CLUSTER_NAMESPACE: el espacio de nombres del clúster. Para los clústeres compartidos, usa el espacio de nombresplatform. Para los clústeres estándar, usa el espacio de nombres del proyecto del clúster.
El resultado es similar a este:
[ { "conditions": [ { "lastTransitionTime": "2023-08-31T22:16:17Z", "message": "", "observedGeneration": 2, "reason": "NodepoolReady", "status": "True", "type": "Ready" }, { "lastTransitionTime": "2023-08-31T22:16:17Z", "message": "", "observedGeneration": 2, "reason": "ReconciliationCompleted", "status": "False", "type": "Reconciling" } ], "name": "worker-node-pool", "readyNodes": 3, "readyTimestamp": "2023-08-31T18:59:46Z", "reconcilingNodes": 0, "stalledNodes": 0, "unknownNodes": 0 } ]
Cambia el tamaño de los grupos de nodos
Puedes cambiar el tamaño de los grupos de nodos de forma manual en un clúster de Kubernetes si aumentas o disminuyes el grupo. No puedes seleccionar un nodo específico para quitar cuando disminuyes un grupo de nodos.
Para escalar un grupo de nodos en un clúster existente, completa los siguientes pasos:
Console
- En el panel, selecciona el proyecto en el que existe el clúster que deseas editar.
- En el menú de navegación, selecciona Kubernetes Engine > Clústeres.
- Selecciona el nombre del clúster con el que está asociado el grupo de nodos. Aparecerá la página Detalles del clúster.
- Haz clic en la pestaña Grupos de nodos.
- Selecciona el ícono edit Editar para el grupo de nodos cuyo tamaño deseas cambiar. Aparecerá el mensaje Editar grupo de nodos.
Actualiza el campo Cantidad de nodos para reflejar la nueva cantidad de nodos requeridos en el grupo de nodos. Puedes aumentar o disminuir la cantidad de nodos para que se adapte a los requisitos de tu carga de trabajo.
Haz clic en Guardar.
Vuelve a la pestaña Grupos de nodos de tu clúster y confirma que el grupo de nodos cuyo tamaño se cambió tenga el estado
Readyy la cantidad correcta de nodos. El grupo de nodos puede tardar unos minutos en escalarse según tu especificación.
API
Abre la especificación de recursos personalizados
Clustercon la CLI de kubectl mediante el editor interactivo:kubectl edit clusters.cluster.gdc.goog/KUBERNETES_CLUSTER_NAME \ -n KUBERNETES_CLUSTER_NAMESPACE \ --kubeconfig MANAGEMENT_API_SERVERReemplaza lo siguiente:
KUBERNETES_CLUSTER_NAME: el nombre del clúster que aloja el grupo de nodos.KUBERNETES_CLUSTER_NAMESPACE: el espacio de nombres del clúster. Para los clústeres compartidos, usa el espacio de nombresplatform. Para los clústeres estándar, usa el espacio de nombres del proyecto del clúster.MANAGEMENT_API_SERVER: la ruta de acceso kubeconfig del servidor de la API zonal en la que se aloja el clúster de Kubernetes. Si no generaste un archivo kubeconfig para el servidor de la API de Management en tu zona objetivo, consulta Recursos del servidor de la API de Management zonal.
Actualiza el campo
nodeCountpara el grupo de nodos cuyo tamaño deseas cambiar:nodePools: # Several lines of code are omitted here. - machineTypeName: n2-standard-2-gdc name: nodepool-1 nodeCount: NUMBER_OF_WORKER_NODESReemplaza
NUMBER_OF_WORKER_NODESpor la cantidad actualizada de nodos trabajadores que se aprovisionarán en el grupo de nodos.Guarda el archivo y sal del editor.
Para verificar que se completó el ajuste de escala de nodos, revisa la configuración del grupo de nodos:
kubectl get clusters.cluster.gdc.goog/KUBERNETES_CLUSTER_NAME \ -n KUBERNETES_CLUSTER_NAMESPACE -o json \ --kubeconfig MANAGEMENT_API_SERVER | jq .status.workerNodePoolStatusesConfirma que el número
readyNodesrefleje la cantidad de nodos que configuraste para el grupo de nodos. El grupo de nodos puede tardar unos minutos en escalarse según tu especificación.
Borrar un grupo de nodos
Cuando se borra un grupo de nodos, se borran los nodos y las rutas a ellos. Estos nodos expulsan y reprograman cualquier pod que se ejecute en ellos. Si los pods tienen selectores de nodos específicos, pueden permanecer en una condición no programable si ningún otro nodo del clúster cumple con los criterios.
Asegúrate de tener al menos tres nodos trabajadores antes de borrar un grupo de nodos para garantizar que tu clúster tenga suficiente espacio de procesamiento para ejecutarse de manera eficaz.
Para borrar un grupo de nodos, completa los siguientes pasos:
Console
En el menú de navegación, selecciona Kubernetes Engine > Clústeres.
Haz clic en el clúster que aloja el grupo de nodos que deseas borrar.
Selecciona Grupos de nodos.
Haz clic en delete Borrar junto al grupo de nodos que deseas borrar.
API
Abre la especificación de recursos personalizados
Clustercon la CLI de kubectl mediante el editor interactivo:kubectl edit clusters.cluster.gdc.goog/KUBERNETES_CLUSTER_NAME \ -n KUBERNETES_CLUSTER_NAMESPACE \ --kubeconfig MANAGEMENT_API_SERVERReemplaza lo siguiente:
KUBERNETES_CLUSTER_NAME: el nombre del clúster.KUBERNETES_CLUSTER_NAMESPACE: el espacio de nombres del clúster. Para los clústeres compartidos, usa el espacio de nombresplatform. Para los clústeres estándar, usa el espacio de nombres del proyecto del clúster.MANAGEMENT_API_SERVER: la ruta de acceso kubeconfig del servidor de la API zonal en la que se aloja el clúster de Kubernetes. Si no generaste un archivo kubeconfig para el servidor de la API de Management en tu zona objetivo, consulta Recursos del servidor de la API de Management zonal.
Quita la entrada del grupo de nodos de la sección
nodePools. Por ejemplo, en el siguiente fragmento, debes quitar los camposmachineTypeName,nameynodeCount:nodePools: # Several lines of code are omitted here. - machineTypeName: n2-standard-2-gdc name: nodepool-1 nodeCount: 3Asegúrate de quitar todos los campos del grupo de nodos que borras.
Guarda el archivo y sal del editor.
¿Qué sigue?
- Mantener clústeres de Kubernetes
- Cargas de trabajo de contenedores en GDC
- Aísla las cargas de trabajo de contenedores