From 4e75fd955a46960f83fdbeb7e5aed35ea81eba43 Mon Sep 17 00:00:00 2001 From: Marwan Ahmed Date: Tue, 21 Dec 2021 20:35:24 +0200 Subject: [PATCH] ignore azure csi topology label for similarity checks and populate it for scale from zero --- cluster-autoscaler/cloudprovider/azure/azure_template.go | 4 ++++ .../processors/nodegroupset/azure_nodegroups.go | 4 ++++ 2 files changed, 8 insertions(+) diff --git a/cluster-autoscaler/cloudprovider/azure/azure_template.go b/cluster-autoscaler/cloudprovider/azure/azure_template.go index 6cbd31adb1cc..cb14edf79892 100644 --- a/cluster-autoscaler/cloudprovider/azure/azure_template.go +++ b/cluster-autoscaler/cloudprovider/azure/azure_template.go @@ -33,6 +33,8 @@ import ( "time" ) +const AzureDiskTopologyKey string = "topology.disk.csi.azure.com/zone" + func buildInstanceOS(template compute.VirtualMachineScaleSet) string { instanceOS := cloudprovider.DefaultOS if template.VirtualMachineProfile != nil && template.VirtualMachineProfile.OsProfile != nil && template.VirtualMachineProfile.OsProfile.WindowsConfiguration != nil { @@ -58,8 +60,10 @@ func buildGenericLabels(template compute.VirtualMachineScaleSet, nodeName string } result[apiv1.LabelTopologyZone] = strings.Join(failureDomains[:], cloudvolume.LabelMultiZoneDelimiter) + result[AzureDiskTopologyKey] = strings.Join(failureDomains[:], cloudvolume.LabelMultiZoneDelimiter) } else { result[apiv1.LabelTopologyZone] = "0" + result[AzureDiskTopologyKey] = "" } result[apiv1.LabelHostname] = nodeName diff --git a/cluster-autoscaler/processors/nodegroupset/azure_nodegroups.go b/cluster-autoscaler/processors/nodegroupset/azure_nodegroups.go index 7462f9a6ea2a..2d78b137e19d 100644 --- a/cluster-autoscaler/processors/nodegroupset/azure_nodegroups.go +++ b/cluster-autoscaler/processors/nodegroupset/azure_nodegroups.go @@ -26,6 +26,9 @@ const AzureNodepoolLegacyLabel = "agentpool" // AzureNodepoolLabel is an AKS label specifying which nodepool a particular node belongs to const AzureNodepoolLabel = "kubernetes.azure.com/agentpool" +// AzureDiskTopologyKey is the topology key of Azure Disk CSI driver +const AzureDiskTopologyKey = "topology.disk.csi.azure.com/zone" + func nodesFromSameAzureNodePool(n1, n2 *schedulerframework.NodeInfo) bool { n1AzureNodePool := n1.Node().Labels[AzureNodepoolLabel] n2AzureNodePool := n2.Node().Labels[AzureNodepoolLabel] @@ -48,6 +51,7 @@ func CreateAzureNodeInfoComparator(extraIgnoredLabels []string) NodeInfoComparat } azureIgnoredLabels[AzureNodepoolLegacyLabel] = true azureIgnoredLabels[AzureNodepoolLabel] = true + azureIgnoredLabels[AzureDiskTopologyKey] = true for _, k := range extraIgnoredLabels { azureIgnoredLabels[k] = true }