Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
Azure Kubernetes Service (AKS) regularly provides new node images, so it's beneficial to upgrade your node images frequently to use the latest AKS features. Linux node images are updated weekly, and Windows node images are updated monthly. Image upgrade announcements are included in the AKS release notes, and it can take up to a week for these updates to be rolled out across all regions. You can also perform node image upgrades automatically and schedule them using planned maintenance. For more information, see Automatically upgrade node images.
This article shows you how to upgrade AKS cluster node images and how to update node pool images without upgrading the Kubernetes version. For information on upgrading the Kubernetes version for your cluster, see Upgrade an AKS cluster.
Note
The AKS cluster must use virtual machine scale sets for the nodes.
It's not possible to downgrade a node image version (for example AKSUbuntu-2204 to AKSUbuntu-1804, or AKSUbuntu-2204-202308.01.0 to AKSUbuntu-2204-202307.27.0).
Connect to your AKS cluster
- Connect to your AKS cluster using the [ - az aks get-credentials][az-aks-get-credentials] command.- az aks get-credentials \ --resource-group $AKS_RESOURCE_GROUP \ --name $AKS_CLUSTER
Check for available node image upgrades
- Check for available node image upgrades using the - az aks nodepool get-upgradescommand.- az aks nodepool get-upgrades \ --nodepool-name $AKS_NODEPOOL \ --cluster-name $AKS_CLUSTER \ --resource-group $AKS_RESOURCE_GROUP
- In the output, find and make note of the - latestNodeImageVersionvalue. This value is the latest node image version available for your node pool.
- Check your current node image version to compare with the latest version using the - az aks nodepool showcommand.- az aks nodepool show \ --resource-group $AKS_RESOURCE_GROUP \ --cluster-name $AKS_CLUSTER \ --name $AKS_NODEPOOL \ --query nodeImageVersion
- If the - nodeImageVersionvalue is different from the- latestNodeImageVersion, you can upgrade your node image.
Upgrade all node images in all node pools
- Upgrade all node images in all node pools in your cluster using the - az aks upgradecommand with the- --node-image-onlyflag.- az aks upgrade \ --resource-group $AKS_RESOURCE_GROUP \ --name $AKS_CLUSTER \ --node-image-only \ --yes
- You can check the status of the node images using the - kubectl get nodescommand.- Note - This command might differ slightly depending on the shell you use. For more information on Windows and PowerShell environments, see the Kubernetes JSONPath documentation. - kubectl get nodes -o jsonpath='{range .items[*]}{.metadata.name}{"\t"}{.metadata.labels.kubernetes\.azure\.com\/node-image-version}{"\n"}{end}'
- When the upgrade completes, use the - az aks showcommand to get the updated node pool details. The current node image is shown in the- nodeImageVersionproperty.- az aks show \ --resource-group $AKS_RESOURCE_GROUP \ --name $AKS_CLUSTER
Upgrade a specific node pool
- Update the OS image of a node pool without doing a Kubernetes cluster upgrade using the - az aks nodepool upgradecommand with the- --node-image-onlyflag.- az aks nodepool upgrade \ --resource-group $AKS_RESOURCE_GROUP \ --cluster-name $AKS_CLUSTER \ --name $AKS_NODEPOOL \ --node-image-only
- You can check the status of the node images with the - kubectl get nodescommand.- Note - This command may differ slightly depending on the shell you use. For more information on Windows and PowerShell environments, see the Kubernetes JSONPath documentation. - kubectl get nodes -o jsonpath='{range .items[*]}{.metadata.name}{"\t"}{.metadata.labels.kubernetes\.azure\.com\/node-image-version}{"\n"}{end}'
- When the upgrade completes, use the - az aks nodepool showcommand to get the updated node pool details. The current node image is shown in the- nodeImageVersionproperty.- az aks nodepool show \ --resource-group $AKS_RESOURCE_GROUP \ --cluster-name $AKS_CLUSTER \ --name $AKS_NODEPOOL
Upgrade node images with node surge
To speed up the node image upgrade process, you can upgrade your node images using a customizable node surge value. By default, AKS uses one extra node to configure upgrades.
- Upgrade node images with node surge using the - az aks nodepool updatecommand with the- --max-surgeflag to configure the number of nodes used for upgrades.- Note - To learn more about the trade-offs of various - --max-surgesettings, see Customize node surge upgrade.- az aks nodepool update \ --resource-group $AKS_RESOURCE_GROUP \ --cluster-name $AKS_CLUSTER \ --name $AKS_NODEPOOL \ --max-surge 33% \ --no-wait
- You can check the status of the node images with the - kubectl get nodescommand.- kubectl get nodes -o jsonpath='{range .items[*]}{.metadata.name}{"\t"}{.metadata.labels.kubernetes\.azure\.com\/node-image-version}{"\n"}{end}'
- Get the updated node pool details using the - az aks nodepool showcommand. The current node image is shown in the- nodeImageVersionproperty.- az aks nodepool show \ --resource-group $AKS_RESOURCE_GROUP \ --cluster-name $AKS_CLUSTER \ --name $AKS_NODEPOOL
Next steps
- For information about the latest node images, see the AKS release notes.
- Learn how to upgrade the Kubernetes version with Upgrade an AKS cluster.
- Automatically apply cluster and node pool upgrades with GitHub Actions.
- Learn more about multiple node pools with Create multiple node pools.
- Learn about upgrading best practices with AKS patch and upgrade guidance.
Azure Kubernetes Service