A component that automatically adjusts the size of a Kubernetes Cluster so that all pods have a place to run and there are no unneeded nodes. Supports several public cloud providers. Version 1.0 (GA) was released with Kubernetes 1.8.
- Kubernetes >=
1.28.0
- Kustomize =
v3.5.3
- Cluster autoscaler image:
registry.sighup.io/autoscaling/cluster-autoscaler:v1.28.2,v1.29.0,v1.30.2,v1.31.0
- Cluster autoscaler repo: Cluster autoscaler at Github
You can deploy cluster autoscaler in your EKS cluster by including the package in your Kustomize project:
kustomization.yaml
file extract:
...
resources:
- katalog/cluster-autoscaler/{v1.28.x,v1.29.x,v1.30.x,v1.31.x}
...
Refer to the Terraform module iam-for-cluster-autoscaler to create the IAM role and the required kustomize patches automatically.
If still you want to create everything manually without using our Terraform Module, you need to patch the service account, the cluster name (for example mycluster
) and the region (for example eu-west-1
) as follows:
sa-patch.yaml
---
apiVersion: v1
kind: ServiceAccount
metadata:
annotations:
eks.amazonaws.com/role-arn: arn:aws:iam::123456789123:role/your-role-name
name: cluster-autoscaler
namespace: kube-system
cluster-autoscaler-patch.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
app: cluster-autoscaler
name: cluster-autoscaler
namespace: kube-system
spec:
template:
spec:
containers:
- name: aws-cluster-autoscaler
env:
- name: AWS_REGION
value: "eu-west-1"
- name: CLUSTER_NAME
value: mycluster
and then add on the kustomization.yaml
file the patches:
kustomization.yaml
file extract:
...
patchesStrategicMerge:
- sa-patch.yaml
- cluster-autoscaler-patch.yaml
...
You can then apply your kustomize project by running the following command:
kustomize build | kubectl apply -f -
For license details please see LICENSE