Skip to content

Latest commit

 

History

History
185 lines (100 loc) · 7.48 KB

README.md

File metadata and controls

185 lines (100 loc) · 7.48 KB

AWS EKS AutoScaler for Node & pod

EKS master Node AutoScaling is fully managed by EKS.

  • There are two Scaling in EKS:
    1. Node AutoScaling (Cluster AutoScaler & karpenter)
    2. POD AutoScaling (Hpa)
  1. Node AutoScaling: It is "Cluster AutoScaler" means increases worker node, For this EKS use aws ASG service(Auto scaling group).

    There are two Autoscaling are available for Node that is "Cluster AutoScaler" & "karpenter".

    for Autoscaling metrics is important, EKS uses aws "Cloud Watch" for matrics the node.

    Matrics means the program keep on monitoring the CPU,RAM of Nodes.

  2. POD AutoScaling:

    For Pod AutoScaling Hpa(Horizontal Pod AutoScaling) is used.

    Kubernetes give metrics server for pod autoscaling, we need to download that metrics server which helps us for AutoScaling.

AutoScaler of Node:

Steps:

  1. Create cluster with enabling asg access.
  2. Download Cluster Autoscaler YAML file.
  3. Edit Cluster Autoscaler YAML file.
  4. Apply Cluster Autoscaler YAML file. (Start Pod)

Step-1: [This command is for create cluster with enable asg (--asg-access) (AutoScaler group)]

   eksctl create cluster  --name pscluster2  --region ap-south-1  --version 1.30  --nodegroup-name psnodegp --instance-types t2.micro --nodes 3  --nodes-min 3  --nodes-max 6  --node-volume-size 8  --node-volume-type gp3  --ssh-access   --enable-ssm --instance-name psworkernode --asg-access  --managed

image

Step-2: [Download asg file (This command download GitHub file named as "cluster-autoscaler-autodiscover.yaml")]

 curl -O https://raw.githubusercontent.com/kubernetes/autoscaler/master/cluster-autoscaler/cloudprovider/aws/examples/cluster-autoscaler-autodiscover.yaml

Step-3: [Open and edit YAML file "cluster-autoscaler-autodiscover.yaml"]

The YAML file sets up permissions and deploys the Cluster Autoscaler pod, which automatically scales our Kubernetes cluster based on workload demands.

 notepad cluster-autoscaler-autodiscover.yaml

Check right version of image as compare to kubernetes version while creating cluster:

image

Set Auto scale down time:

image

In this file we replace "" > "pscluster2" my cluster name

Step-4: [Apply file command(Create auto scaler pod)]

kubectl apply -f cluster-autoscaler-autodiscover.yaml

After apply check cluster-autoscaler pod run:

 kubectl get pods -n kube-system

image

Check lastest version or on which version our kubernetes work and use that image for autoscaler pod: (https://github.com/kubernetes/autoscaler/releases)

In my case i use version -->> --version 1.30 so i use image version ":v1.30.1"

command for deployment.apps/cluster-autoscaler image updated: (Optional commad/not needed)

  kubectl set image deployment cluster-autoscaler -n kube-system cluster-autoscaler=registry.k8s.io/autoscaling/cluster:v1.30.1

we can check nodes details info using command:

  kubectl describe nodes

we can check specific nodes details info using command:

  kubectl describe nodes <nodeName>

AutoScaling of POD:

The manual Horizontal scaling of pods we can done using command:

kubectl scale deployment myps1  --replicas=5
  • Steps: (Steps for Autoscaling of pods)
  1. Install/Download Metrics server & check that is running.
  2. Start Hps for deployment.
  • Note:

    There is no program running which give metrics of pods, without metrics server we can't use AutoScaling because of this Kubernetes provide "Metrics server".

    Metrics server keep on monitoring on all pods(CPU, RAM), If load come then auto horizontal scaling done by using Hpa.

    Metrics server is one kind of program running as pod.

    Hpa: Horizontal pod AutoScaling

Step-1: [Install metrics server from YAML file]

Search on browser 'kubernetes metric server' Metrics-server-pod-link

kubectl apply -f https://github.com/kubernetes-sigs/metrics-server/releases/latest/download/components.yaml

image

Check running metrics server pod command:

kubectl get pods -n kube-system

image

kubectl get deployment -n kube-system

image

Step-2: [Start Hpa for deployment]

We can launch a pod with Hpa, it means we set that pod/deployment as Hpa which autoscale according to load.

Hpa is just progarm which attach to Pod/deployment.

for thid i use load generator app which provided by Kubernetes for checking AutoScaling working Load-generator-app-link

To demonstrate a HorizontalPodAutoscaler, you will first start a Deployment that runs a container using the hpa-example image, and expose it as a Service using the following manifest:

kubectl apply -f https://k8s.io/examples/application/php-apache.yaml

image

Create the HorizontalPodAutoscaler:

kubectl autoscale deployment php-apache --cpu-percent=50 --min=1 --max=10

Here we use autoscale keyword which start hpa and set cpu limit=50 and minimum and maximum replicas/scale limit.

image

Check Hpa start cmd:

kubectl get hpa

image

  • Now Increase load (This command need fresh terminal or clear terminal):

    kubectl run -i --tty load-generator --rm --image=busybox:1.28 --restart=Never -- /bin/sh -c "while sleep 0.01; do wget -q -O- http://php-apache; done"

image

  • We can check the the our load increases by watch command:

    kubectl get hpa php-apache --watch

image

See that Autoscaling of Pods and Nodes work:

  • Pods: The metrics server keep on monitoring on pod as soon as load increases on pod/deployment, It send information to hpa (Horizontal pod autoscaler) and based upon that information Hpa keeps on launching & terminating pods.

image

Screenshot 2024-08-10 115601

  • Nodes: "Cluster Autoscaler"(YMAl file) keep on monitoring and send information to "asg". It capture information & that information send to asg and based upon information it keeps in launching and terminating Nodes(Instances).

image

Screenshot 2024-08-10 115803

  • Note:

    as soon as we stop load generator then 1st pods scale-in to 1 and then Nodes Scale-in to 3 because min=3

image