Followers

Cluster Autoscaler

 

AutoScaler

  • Responsible for dynamically scale the nodes in the node group
  • Runs as deployment
  • Decides on the basis of CPU & RAM availability
  • a mixture of on-demand and spot instance possible

LAB

The cluster autoscaler automatically launches additional worker nodes if more resources are needed, and shutdown worker nodes if they are underutilized. The autoscaling works within a nodegroup, hence create a nodegroup first which has this feature enabled.

Create AutoScale node group in AZ by creating below yaml file (eks-auto.yaml)

    apiVersion: eksctl.io/v1alpha5
    kind: ClusterConfig

    metadata:
      name: EKS-raman-cluster
      region: us-east-1

    nodeGroups:
      - name: scale-east1c
        instanceType: t2.small
        desiredCapacity: 1
        maxSize: 5
        availabilityZones: ["us-east-1c"]
        iam:
          withAddonPolicies:
            autoScaler: true
        labels:
          nodegroup-type: stateful-east1c
          instance-type: onDemand
        ssh: # use existing EC2 key
          publicKeyName: vdevops
      - name: scale-east1d
        instanceType: t2.small
        desiredCapacity: 1
        maxSize: 5
        availabilityZones: ["us-east-1a"]
        iam:
          withAddonPolicies:
            autoScaler: true
        labels:
          nodegroup-type: stateful-east1d
          instance-type: onDemand
        ssh: # use existing EC2 key
          publicKeyName: vdevops
      - name: scale-spot
        desiredCapacity: 1
        maxSize: 5
        instancesDistribution:
          instanceTypes: ["t2.small", "t3.small"]
          onDemandBaseCapacity: 0
          onDemandPercentageAboveBaseCapacity: 0
        availabilityZones: ["us-east-1c", "us-east-1a"]
        iam:
          withAddonPolicies:
            autoScaler: true
        labels:
          nodegroup-type: stateless-workload
          instance-type: spot
        ssh:
          publicKeyName: vdevops

Run Below command to create nodegroup with autoscaler enabled

    eksctl create nodegroup --config-file=eks-auto.yaml
    # Run below command to check the nodes get created or not
    kubectl get nodes
    # Run below command to delete ng-1 node group
    eksctl delete nodegroup -f eks.yaml --include="ng-1"
    eksctl delete nodegroup -f eks.yaml --include="ng-1" --approve

Deploy the AutoScaler

    kubectl apply -f https://raw.githubusercontent.com/kubernetes/autoscaler/master/cluster-autoscaler/cloudprovider/aws/examples/cluster-autoscaler-autodiscover.yaml

put required annotation to the deployment:

    kubectl -n kube-system annotate deployment.apps/cluster-autoscaler cluster-autoscaler.kubernetes.io/safe-to-evict="false"

get the autoscaler image version:

      open https://github.com/kubernetes/autoscaler/releases and get the latest release version matching your Kubernetes version, e.g. Kubernetes 1.14 => check for 1.14.n  where "n" is the latest release version. change cluster name (EKS-raman-cluster) and version of EKS
      
      kubectl -n kube-system edit deployment.apps/cluster-autoscaler

Create nginx-deployment.yaml

    apiVersion: apps/v1

    kind: Deployment

    metadata:

      name: test-autoscaler

    spec:

      selector:

        matchLabels:

          app: nginx

      replicas: 1

      template:

        metadata:

          labels:

            service: nginx

            app: nginx

        spec:

          containers:

          - image: nginx

            name: test-autoscaler

            resources:

              limits:

                cpu: 300m

                memory: 512Mi

              requests:

                cpu: 300m

                memory: 512Mi

          nodeSelector:

            instance-type: spot

Check the Log details

  kubectl -n kube-system logs deployment.apps/cluster-autoscaler

COMMENTS

BLOGGER
Sneeit.Com
Name

Ansible,6,AWS,1,Azure DevOps,1,Containerization with docker,2,DevOps,2,Docker file with buildkit,1,Docker file with buildx,1,Docker Image Scan,1,Docker Quiz,1,Docker Swarm,1,DockerCompose,1,ELK,2,git,2,git quiz,1,Git Worksheet,1,headless service DNS service record,1,ITIL,1,ITSM,1,Jira,3,Kubernetes,1,Kubernetes Quiz,5,SAST DAST Security Testing,1,SDLC Quiz,5,SonarQube,3,Splunk,2,vagrant kubernetes,1,Windows,1,YAML Basics,1,
ltr
static_page
DevOpsWorld: Cluster Autoscaler
Cluster Autoscaler
DevOpsWorld
https://www.devopsworld.co.in/p/cluster-autoscaler.html
https://www.devopsworld.co.in/
https://www.devopsworld.co.in/
https://www.devopsworld.co.in/p/cluster-autoscaler.html
true
5997357714110665304
UTF-8
Loaded All Posts Not found any posts VIEW ALL Readmore Reply Cancel reply Delete By Home PAGES POSTS View All RECOMMENDED FOR YOU LABEL ARCHIVE SEARCH ALL POSTS Not found any post match with your request Back Home Sunday Monday Tuesday Wednesday Thursday Friday Saturday Sun Mon Tue Wed Thu Fri Sat January February March April May June July August September October November December Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec just now 1 minute ago $$1$$ minutes ago 1 hour ago $$1$$ hours ago Yesterday $$1$$ days ago $$1$$ weeks ago more than 5 weeks ago Followers Follow THIS PREMIUM CONTENT IS LOCKED STEP 1: Share to a social network STEP 2: Click the link on your social network Copy All Code Select All Code All codes were copied to your clipboard Can not copy the codes / texts, please press [CTRL]+[C] (or CMD+C with Mac) to copy Table of Content