A node pool is a group of nodes within a Kubernetes cluster that all have the same
configuration. Node pools use a NodePool specification. Each node in the pool
has a Kubernetes node label, which has the name of the node pool as its value.
By default, all new node pools run the same version of Kubernetes as the control
plane.
When you create a Kubernetes cluster, the number of nodes and type of nodes that you specify create the first node pool of the cluster. You can add additional node pools of different sizes and types to your cluster. All nodes in any given node pool are identical to one another.
Custom node pools are useful when scheduling pods that require more resources than others, such as more memory or local disk space. You can use node taints if you need more control over scheduling the pods.
You can create and delete node pools individually without affecting the whole cluster. You cannot configure a single node in a node pool. Any configuration changes affect all nodes in the node pool.
You can resize node pools in a cluster by upscaling or downscaling the pool. Downscaling a node pool is an automated process where you decrease the pool size and the GDC system automatically drains and evicts an arbitrary node. You cannot select a specific node to remove when downscaling a node pool.
Before you begin
To view and manage node pools in a Kubernetes cluster, you must have the following roles:
- User Cluster Admin (user-cluster-admin)
- User Cluster Node Viewer (user-cluster-node-viewer)
These roles are not bound to a namespace.
Add a node pool
When creating a Kubernetes cluster from the GDC console, you can customize the default node pool and create additional node pools before the cluster creation initializes. If you must add a node pool to an existing Kubernetes cluster, complete the following steps:
Console
- In the navigation menu, select Kubernetes Engine > Clusters.
- Click the cluster from the cluster list. The Cluster details page is displayed.
- Select Node pools > Add node pool.
- Assign a name for the node pool. You cannot modify the name after you create the node pool.
- Specify the number of worker nodes to create in the node pool.
- Select your machine class that best suits your workload requirements. The
machine classes show in the following settings:
- Machine type
- vCPU
- Memory
 
- Click Save.
API
- Open the - Clustercustom resource spec with the- kubectlCLI using the interactive editor:- kubectl edit clusters.cluster.gdc.goog/KUBERNETES_CLUSTER_NAME -n platform \ --kubeconfig MANAGEMENT_API_SERVER- Replace the following: - KUBERNETES_CLUSTER_NAME: The name of the cluster.
- MANAGEMENT_API_SERVER: The zonal API server's kubeconfig path where the Kubernetes cluster is hosted. If you have not yet generated a kubeconfig file for the API server in your targeted zone, see Sign in for details.
 
- Add a new entry in the - nodePoolssection:- nodePools: ... - machineTypeName: MACHINE_TYPE name: NODE_POOL_NAME nodeCount: NUMBER_OF_WORKER_NODES taints: TAINTS labels: LABELS acceleratorOptions: gpuPartitionScheme: GPU_PARTITION_SCHEME- Replace the following: - MACHINE_TYPE: The machine type for the worker nodes of the node pool. View the available machine types for what is available to configure.
- NODE_POOL_NAME: The name of the node pool.
- NUMBER_OF_WORKER_NODES: The number of worker nodes to provision in the node pool.
- TAINTS: The taints to apply to the nodes of this node pool. This is an optional field.
- LABELS: The labels to apply to the nodes of this node pool. It contains a list of key-value pairs. This is an optional field.
- GPU_PARTITION_SCHEME: The GPU partitioning scheme, if you're running GPU workloads. For example,- mixed-2. The GPU is not partitioned if this field is not set. For available Multi-Instance GPU (MIG) profiles, see Supported MIG profiles.
 
- Save the file and exit the editor. 
View node pools
To view existing node pools in a Kubernetes cluster, complete the following steps:
Console
- In the navigation menu, select Kubernetes Engine > Clusters.
- Click the cluster from the cluster list. The Cluster details page is displayed.
- Select Node pools.
The list of node pools running in the cluster is displayed. You can manage the node pools of the cluster from this page.
API
- View the node pools of a specific Kubernetes cluster: - kubectl get clusters.cluster.gdc.goog/KUBERNETES_CLUSTER_NAME -n platform \ -o json --kubeconfig MANAGEMENT_API_SERVER | \ jq .status.workerNodePoolStatuses- The output is similar to the following: - [ { "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 } ]
Delete a node pool
Deleting a node pool deletes the nodes and routes to them. These nodes evict and reschedule any pods running on them. If the pods have specific node selectors, the pods might remain in a non-schedulable condition if no other node in the cluster satisfies the criteria.
Ensure you have at least three worker nodes before deleting a node pool to ensure your cluster has enough compute space to run effectively.
To delete a node pool, complete the following steps:
Console
- In the navigation menu, select Kubernetes Engine > Clusters. 
- Click the cluster that is hosting the node pool you want to delete. 
- Select Node pools. 
- Click delete Delete next to the node pool to delete. 
API
- Open the - Clustercustom resource spec with the- kubectlCLI using the interactive editor:- kubectl edit clusters.cluster.gdc.goog/KUBERNETES_CLUSTER_NAME -n platform \ --kubeconfig MANAGEMENT_API_SERVER- Replace the following: - KUBERNETES_CLUSTER_NAME: The name of the cluster.
- MANAGEMENT_API_SERVER: The zonal API server's kubeconfig path where the Kubernetes cluster is hosted. If you have not yet generated a kubeconfig file for the API server in your targeted zone, see Sign in for details.
 
- Remove the node pool entry from the - nodePoolssection. For example, in the following snippet, you must remove the- machineTypeName,- name, and- nodeCountfields:- nodePools: ... - machineTypeName: n2-standard-2-gdc name: nodepool-1 nodeCount: 3- Be sure to remove all fields for the node pool you are deleting. 
- Save the file and exit the editor.