Skip to content

Releases: kubernetes/autoscaler

cluster-autoscaler-chart-9.35.0

05 Feb 15:00
e5625a4
Compare
Choose a tag to compare

Scales Kubernetes worker nodes within autoscaling groups.

Cluster Autoscaler 1.28.3

18 Apr 21:44
6685cb4
Compare
Choose a tag to compare

Changelog

General

  • Update k/k deps to 1.28.6 (#6465)
  • Update Golang in builder Dockerfile to 1.20.12 (#6355)

AWS

  • Update cloudprovider/aws/aws-sdk-go to 1.48.7 so we support dynamic auth token (#6379)

CAPI

  • kubeClientBurst and kubeClientQPS flags are now passed to the clusterapi provider k8s clients (#6439)

Civo

  • Implement TemplateNodeInfo() method for civo cloudprovider (#6342)
  • Calculate the real value for template using node group (#6342)
  • Add GPU count to node templates (#6403)

## Hetzner

  • Fixed a bug where failed servers are kept for longer than necessary (#6365)

Images

  • registry.k8s.io/autoscaling/cluster-autoscaler:v1.28.3
  • registry.k8s.io/autoscaling/cluster-autoscaler-arm64:v1.28.3
  • registry.k8s.io/autoscaling/cluster-autoscaler-amd64:v1.28.3
  • registry.k8s.io/autoscaling/cluster-autoscaler-s390x:v1.28.3

Full Changelog: cluster-autoscaler-1.28.2...cluster-autoscaler-1.28.3

Cluster Autoscaler 1.29.1

18 Apr 21:56
4b73b3e
Compare
Choose a tag to compare

Changelog

General

  • Restore flags for setting QPS limit in CA (#6409)
  • Update k/k deps to 1.29.1 (#6466)

CAPI

  • kubeClientBurst and kubeClientQPS flags are now passed to the clusterapi provider k8s clients (#6438)

Civo

  • Add GPU count to node template (#6404)

Images

  • registry.k8s.io/autoscaling/cluster-autoscaler:v1.29.1
  • registry.k8s.io/autoscaling/cluster-autoscaler-arm64:v1.29.1
  • registry.k8s.io/autoscaling/cluster-autoscaler-amd64:v1.29.1
  • registry.k8s.io/autoscaling/cluster-autoscaler-s390x:v1.29.1

Full Changelog: cluster-autoscaler-1.29.0...cluster-autoscaler-1.29.1

Cluster Autoscaler 1.27.6

18 Apr 21:23
7da5fe7
Compare
Choose a tag to compare

Changelog

General

  • Update k/k deps to 1.27.10 (#6464)
  • Updated to go 1.20.12 (#6354)

AWS

  • Update cloudprovider/aws/aws-sdk-go to 1.48.7 so we support dynamic auth token (#6380)

Brightbox

  • The Brightbox provider now recognises an 'additional_groups' key in the configuration ConfigMap.
    No changes are required by provider users unless they wish to take advantage of the additional functionality. (#5407)
  • Add support for building new nodes using an image name as well as an ID. (#5764)

ClusterAPI

  • kubeClientBurst and kubeClientQPS flags are now passed to the clusterapi provider k8s clients (#6440)

Hetzner

  • Fixed a bug where failed servers are kept for longer than necessary (#6366)

Images

  • registry.k8s.io/autoscaling/cluster-autoscaler:v1.27.6
  • registry.k8s.io/autoscaling/cluster-autoscaler-arm64:v1.27.6
  • registry.k8s.io/autoscaling/cluster-autoscaler-amd64:v1.27.6
  • registry.k8s.io/autoscaling/cluster-autoscaler-s390x:v1.27.6

Full Changelog: cluster-autoscaler-1.27.5...cluster-autoscaler-1.27.6

Cluster Autoscaler 1.26.7

18 Apr 20:57
Compare
Choose a tag to compare

Changelog

General

  • Updated to go 1.19.13 (#6353)

AWS

  • Update cloudprovider/aws/aws-sdk-go to 1.48.7 so we support dynamic auth token (#6381)

Brightbox

  • The Brightbox provider now recognises an 'additional_groups' key in the configuration ConfigMap.
    No changes are required by provider users unless they wish to take advantage of the additional functionality. (#5407)
  • Add support for building new nodes using an image name as well as an ID. (#5764)

Hetzner

  • Fixed a bug where failed servers are kept for longer than necessary (#6367)

Images

  • registry.k8s.io/autoscaling/cluster-autoscaler:v1.26.7
  • registry.k8s.io/autoscaling/cluster-autoscaler-arm64:v1.26.7
  • registry.k8s.io/autoscaling/cluster-autoscaler-amd64:v1.26.7

Full Changelog: cluster-autoscaler-1.26.6...cluster-autoscaler-1.26.7

Cluster Autoscaler 1.29.0

27 Dec 17:25
33fb788
Compare
Choose a tag to compare

Deprecations

  • --ignore-taint flag and ignore-taint.cluster-autoscaler.kubernetes.io/ taint prefix are now deprecated. Instead use:
    • --status-taint flag or status-taint.cluster-autoscaler.kubernetes.io/ taint prefix for taints that denote node status.
    • --startup-taint flag or startup-taint.cluster-autoscaler.kubernetes.io/ taint prefix for taints that are used to prevent pods from scheduling before node is fully initialized (e.g. when using daemonset to install device plugin).
    • For backward compatibility --ignore-taint flag and ignore-taint.cluster-autoscaler.kubernetes.io/ continues to work with behavior identical to startup taint (which is the same behavior it had before).
    • Please see FAQ for more details. - #6132, #6218
  • Flags that were unused in the code (i.e. setting them had no effect) were deprecated and will be removed in the future release. Affected flags are: --node-autoprovisioning-enabled and --max-autoprovisioned-node-group-count.

General

  • Adds new flag --bypassed-scheduler-names with default empty value to maintain original behaviour.
    If flag is set to non-empty list, CA will not wait for schedulers (listed in the flag value) to mark pods as unschedulable and will evaluate non processed pods. Furthermore, if bypassed schedulers are non-empty CA will not wait for pods to reach a certain age to scale-up, effectively ignoring unschedulablePodTimeBuffer - #6235
    • Enabling this feature can improve autoscaling latency (CA will react to pods faster), but it can also increase load on CA in case of very large scale-ups (thousands of pending pods). This is because limited scheduler throughput can effectively act as a rate limiter, protecting CA from having to process a scale-up of too many pods at the same time. We believe this change will be beneficial in vast majority of environments, but given that CA scalability varies greatly between cloud providers we recommend testing this feature before enabling it in large clusters.
  • A new flag (--drain-priority-config) is introduced which allows users to configure drain behavior during scale-down based on pod priority. The new flag is mutually exclusive with --max-graceful-termination-sec. --max-graceful-termination-sec can still be used if the new configuration options are not needed. The default behavior is preserved (simple config, default value of --max-graceful-termination-sec). - #6139
  • Added --dynamic-node-delete-delay-after-taint-enabled flag. Enabling this flag changes delay between tainting and draining a node from constant delay to a dynamic one based on Kubernetes api-server latency. This minimizes the risk of race conditions if api-server connection is slow and improves scale-down throughput when it's fast. - #6019
  • Add structured logging support via --logging-format json - #6035
  • Introduced a new node_group_target_count metric that keeps track of target sizes of each NodeGroup. This metric is only available if --emit-per-nodegroup-metrics flag is enabled. - #6361
  • Introduced a new node_taints_count metric tracking different types of taints in the cluster. - #6201
  • New command line option --kube-api-content-type is added to specify content type to communicate with apiserver. This option also changes default content type from "application/json" to "application/vnd.kubernetes.protobuf". - #6114
  • Fixed a bug where resource requests of restartable init containers were not included in utilization calculation. - #6225
  • Fixed a bug where CA might have created less nodes than desired with a message about "Capping binpacking after exceeding threshold of 4 nodes" even though it then didn't actually add four new nodes. - #6165
  • Fixed support for --feature-gates=ContextualLogging=true. - #6162
  • Fixed a bug where scale down may have failed with "daemonset.apps not found". - #6122
  • Optimized CA memory usage. - #6159, #6110
  • Disambiguated wording in the log messages related to node removal ineligibility caused by high resource allocation. - #6223
  • Pods with the "cluster-autoscaler.kubernetes.io/safe-to-evict": "false" annotation will now always report an annotation-related warning message if they block scale-down (where previously they might've reported e.g. a message about not being replicated).- #6077

AWS

  • Added c7a, r7i, mac2-m2 families and size in i4i, c7i.metal, r7a.metal, r7iz.metal for Amazon EC2 instances static list. - #6347
  • Added p5.48xlarge - #6131
  • Updated cloudprovider/aws/aws-sdk-go to 1.48.7 in order to support dynamic auth token. - #6325
  • Fixed an issue where the capacityType label inferred from an empty AWS ManagedNodeGroup does not match the same label on the nodes after it scales from 0 -> 1. - #6261
  • Introduced caching to reduce volume of DescribeLaunchTemplateVersions API calls made by Cluster Autoscaler. - #6245
  • Nodes annotated with k8s.io/cluster-autoscaler-enabled=false will be skipped by CA and would no longer produce spammy logs about missing AWS instances. - #6265, #6301
  • Added additional log output when updating the ASG information form AWS. - #6282
  • Fixed a bug where CA may tried to remove an instance that was already in Terminated state. - #6166
  • Scale up from 0 now working with existing AWS EBS CSI PersistentVolume without having to add tag to ASG. - #6090

Azure

  • Removed AKS vmType. - #6186

Civo

  • Introduced support for scaling NodeGroup from 0. - #6322

Cluster API

  • Users of Cluster API can override the default architecture to consider in the templates for autoscaling from zero so that pods requesting non-amd64 nodes in their node selector terms can trigger the scale-up in non-amd64 single-arch clusters. - #6066

Equinix Metal

  • The packet provider and its configuration parameters are now deprecated in favor of equinixmetal - #6085
    • The cluster-autoscaler --cloud-provider flag should now be set to equinixmetal. For backward compatibility, "--cloud-provider=packet" continues to work
    • "METAL_AUTH_TOKEN" replaces "PACKET_AUTH_TOKEN". For backward compatibility, the latter still works.
    • "EQUINIX_METAL_MANAGER" replaces "PACKET_MANAGER". For backward compatibility, the latter still works.
    • Each node managed by cloud-provider "equinixmetal" will be labeled with the "METAL_CONTROLLER_NODE_IDENTIFIER_LABEL" defined label. For backward compatibility, "PACKET_CONTROLLER_NODE_IDENTIFIER_LABEL" still works.
  • We now use metros in the Equinix Metal (Packet) cloudprovider. Facilities support has been removed. - #6078

GCE

  • Flag --gce-expander-ephemeral-storage-support is now Deprecated. The ephemeral-storage support is always enabled and the flag itself would be ignored.
  • Support for paginated MIG instance listing. - #6376
  • Improved reporting of errors related to GCE Reservations. - #6093

gRPC

  • Timeout of grpc calls can be specified through cloud-config. - #6373
  • grpc based cloud providers can now pass the grpc error code 12, Unimplemented, to signal they do not implement optional methods. - #5937
  • Fixed: cluster-autoscaler thinks newly scaled up nodegroup using externalgrpc provider has MaxNodeProvisionTime set as 0 seconds and expects the new node to be registered in 0-10 seconds instead of the default 15m. Check #5935 for more info. - #5936

Hetzner

  • Fixed a bug where failed servers are kept for longer than necessary. - #6364
  • Fixed a bug where too many requests are sent to the Hetzner Cloud API, causing Rate Limit issues. - #6308
  • Each node pool can now have different init configs. - #6184

Kwok

Images

  • registry.k8s.io/autoscaling/cluster-autoscaler:v1.29.0
  • registry.k8s.io/autoscaling/cluster-autoscaler-arm64:v1.29.0
  • registry.k8s.io/autoscaling/cluster-autoscaler-amd64:v1.29.0
  • registry.k8s.io/autoscaling/cluster-autoscaler-s390x:v1.29.0

cluster-autoscaler-chart-9.34.1

19 Dec 11:40
90361b4
Compare
Choose a tag to compare

Scales Kubernetes worker nodes within autoscaling groups.

cluster-autoscaler-chart-9.34.0

06 Dec 09:34
8f75e9c
Compare
Choose a tag to compare

Scales Kubernetes worker nodes within autoscaling groups.

cluster-autoscaler-1.28.2

05 Dec 17:36
4c3ee59
Compare
Choose a tag to compare

Changelog

General

  • Fixed an issue causing --leader-elect flag to crash CA on startup (#6330)

Images

  • registry.k8s.io/autoscaling/cluster-autoscaler:v1.28.2
  • registry.k8s.io/autoscaling/cluster-autoscaler-arm64:v1.28.2
  • registry.k8s.io/autoscaling/cluster-autoscaler-amd64:v1.28.2
  • registry.k8s.io/autoscaling/cluster-autoscaler-s390x:v1.28.2

Full Changelog: cluster-autoscaler-1.28.1...cluster-autoscaler-1.28.2

Cluster Autoscaler 1.27.5

05 Dec 17:33
fe7e07d
Compare
Choose a tag to compare

Changelog

General

  • Fixed an issue causing --leader-elect flag to crash CA on startup (#6331)

Images

  • registry.k8s.io/autoscaling/cluster-autoscaler:v1.27.5
  • registry.k8s.io/autoscaling/cluster-autoscaler-arm64:v1.27.5
  • registry.k8s.io/autoscaling/cluster-autoscaler-amd64:v1.27.5
  • registry.k8s.io/autoscaling/cluster-autoscaler-s390x:v1.27.5

Full Changelog: cluster-autoscaler-1.27.4...cluster-autoscaler-1.27.5