Un pool de nœuds est un groupe de nœuds au sein d'un cluster Kubernetes qui possèdent tous la même configuration. Les pools de nœuds utilisent une spécification NodePool
. Chaque nœud du pool possède une étiquette de nœud Kubernetes dont la valeur est le nom du pool de nœuds.
Par défaut, tous les nouveaux pools de nœuds exécutent la même version de Kubernetes que le plan de contrôle.
Lorsque vous créez un cluster Kubernetes, le nombre et le type de nœuds que vous spécifiez créent le premier pool de nœuds du cluster. Vous pouvez ajouter à votre cluster d'autres pools de nœuds de tailles et de types différents. Tous les nœuds d'un pool de nœuds donné sont identiques.
Les pools de nœuds personnalisés sont utiles lorsque vous planifiez des pods nécessitant plus de ressources que d'autres, par exemple plus de mémoire ou d'espace disque local. Vous pouvez utiliser des rejets de nœuds si vous avez besoin de mieux contrôler la planification des pods.
Vous pouvez créer et supprimer des pools de nœuds individuellement sans affecter l'ensemble du cluster. Vous ne pouvez pas configurer un seul nœud dans un pool de nœuds. Toute modification de la configuration affecte tous les nœuds du pool de nœuds.
Vous pouvez redimensionner des pools de nœuds dans un cluster en augmentant ou en diminuant la taille du pool. La réduction d'un pool de nœuds est un processus automatisé qui consiste à diminuer la taille du pool. Le système GDC vide et évince automatiquement un nœud arbitraire. Vous ne pouvez pas sélectionner un nœud spécifique à supprimer lorsque vous réduisez la taille d'un pool de nœuds.
Avant de commencer
Pour afficher et gérer les pools de nœuds dans un cluster Kubernetes, vous devez disposer des rôles suivants :
- Administrateur de cluster d'utilisateur (
user-cluster-admin
) - Lecteur de nœuds de cluster d'utilisateur (
user-cluster-node-viewer
)
Ces rôles ne sont pas liés à un espace de noms.
Ajouter un pool de nœuds
Lorsque vous créez un cluster Kubernetes à partir de la console GDC, vous pouvez personnaliser le pool de nœuds par défaut et créer des pools de nœuds supplémentaires avant l'initialisation de la création du cluster. Si vous devez ajouter un pool de nœuds à un cluster Kubernetes existant, procédez comme suit :
Console
- Dans le menu de navigation, sélectionnez Kubernetes Engine > Clusters.
- Cliquez sur le cluster dans la liste des clusters. La page Détails du cluster s'affiche.
- Sélectionnez Pools de nœuds> Ajouter un pool de nœuds.
- Attribuez un nom au pool de nœuds. Vous ne pouvez pas modifier le nom après avoir créé le pool de nœuds.
- Spécifiez le nombre de nœuds de calcul à créer dans le pool de nœuds.
- Sélectionnez la classe de machine qui correspond le mieux aux exigences de votre charge de travail. Les classes de machines s'affichent dans les paramètres suivants :
- Type de machine
- vCPU
- Mémoire
- Cliquez sur Enregistrer.
API
Ouvrez la spécification de la ressource personnalisée
Cluster
avec la CLIkubectl
à l'aide de l'éditeur interactif :kubectl edit clusters.cluster.gdc.goog/KUBERNETES_CLUSTER_NAME -n platform \ --kubeconfig MANAGEMENT_API_SERVER
Remplacez les éléments suivants :
KUBERNETES_CLUSTER_NAME
: nom du cluster.MANAGEMENT_API_SERVER
: chemin d'accès kubeconfig du serveur d'API zonal où le cluster Kubernetes est hébergé. Si vous n'avez pas encore généré de fichier kubeconfig pour le serveur d'API dans votre zone cible, consultez Se connecter pour en savoir plus.
Ajoutez une entrée dans la section
nodePools
:nodePools: ... - machineTypeName: MACHINE_TYPE name: NODE_POOL_NAME nodeCount: NUMBER_OF_WORKER_NODES taints: TAINTS labels: LABELS acceleratorOptions: gpuPartitionScheme: GPU_PARTITION_SCHEME
Remplacez les éléments suivants :
MACHINE_TYPE
: type de machine pour les nœuds de calcul du pool de nœuds. Consultez les types de machines disponibles pour connaître les configurations possibles.NODE_POOL_NAME
: nom du pool de nœuds.NUMBER_OF_WORKER_NODES
: nombre de nœuds de calcul à provisionner dans le pool de nœuds.TAINTS
: rejets à appliquer aux nœuds de ce pool de nœuds. Ce champ est facultatif.LABELS
: libellés à appliquer aux nœuds de ce pool de nœuds. Il contient une liste de paires clé/valeur. Ce champ est facultatif.GPU_PARTITION_SCHEME
: schéma de partitionnement du GPU, si vous exécutez des charges de travail GPU. Exemple :mixed-2
Le GPU n'est pas partitionné si ce champ n'est pas défini. Pour connaître les profils MIG (Multi-Instance GPU) disponibles, consultez Profils MIG compatibles.
Enregistrez le fichier et quittez l'éditeur.
Afficher les pools de nœuds
Pour afficher les pools de nœuds existants dans un cluster Kubernetes, procédez comme suit :
Console
- Dans le menu de navigation, sélectionnez Kubernetes Engine > Clusters.
- Cliquez sur le cluster dans la liste des clusters. La page Détails du cluster s'affiche.
- Sélectionnez Pools de nœuds.
La liste des pools de nœuds exécutés dans le cluster s'affiche. Vous pouvez gérer les pools de nœuds du cluster depuis cette page.
API
Affichez les pools de nœuds d'un cluster Kubernetes spécifique :
kubectl get clusters.cluster.gdc.goog/KUBERNETES_CLUSTER_NAME -n platform \ -o json --kubeconfig MANAGEMENT_API_SERVER | \ jq .status.workerNodePoolStatuses
Le résultat ressemble à ce qui suit :
[ { "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 } ]
Supprimer un pool de nœuds
La suppression d'un pool de nœuds supprime aussi bien les nœuds que les routes qui les desservent. Ces nœuds évinceront et replanifieront tous les pods qui s'y exécutent. Si les pods présentent des sélecteurs de nœuds spécifiques, ils peuvent rester dans un état non planifiable si aucun autre nœud du cluster ne répond aux critères spécifiés.
Assurez-vous d'avoir au moins trois nœuds de calcul avant de supprimer un pool de nœuds. Cela permettra à votre cluster de disposer de suffisamment d'espace de calcul pour fonctionner efficacement.
Pour supprimer un pool de nœuds, procédez comme suit :
Console
Dans le menu de navigation, sélectionnez Kubernetes Engine > Clusters.
Cliquez sur le cluster qui héberge le pool de nœuds que vous souhaitez supprimer.
Sélectionnez Pools de nœuds.
Cliquez sur delete Supprimer à côté du pool de nœuds à supprimer.
API
Ouvrez la spécification de la ressource personnalisée
Cluster
avec la CLIkubectl
à l'aide de l'éditeur interactif :kubectl edit clusters.cluster.gdc.goog/KUBERNETES_CLUSTER_NAME -n platform \ --kubeconfig MANAGEMENT_API_SERVER
Remplacez les éléments suivants :
KUBERNETES_CLUSTER_NAME
: nom du cluster.MANAGEMENT_API_SERVER
: chemin d'accès kubeconfig du serveur d'API zonal où le cluster Kubernetes est hébergé. Si vous n'avez pas encore généré de fichier kubeconfig pour le serveur d'API dans votre zone cible, consultez Se connecter pour en savoir plus.
Supprimez l'entrée du pool de nœuds de la section
nodePools
. Par exemple, dans l'extrait de code suivant, vous devez supprimer les champsmachineTypeName
,name
etnodeCount
:nodePools: ... - machineTypeName: n2-standard-2-gdc name: nodepool-1 nodeCount: 3
Veillez à supprimer tous les champs du pool de nœuds que vous supprimez.
Enregistrez le fichier et quittez l'éditeur.