Edit me

Onboarding your EKS clusters to Compute Copilot for EKS

Why use Compute Copilot EKS?

Learn more about how Compute Copilot for EKS can help you to put your EKS cost optimization on auto-pilot here.

Pre-requisites:

  1. You must be logged in to your nOps account
  2. Your AWS account must be configured to your nOps account.
  3. You must have Kubernetes cluster with Karpenter installed.

About Compute Copilot for EKS:

Karpenter offers significant advancements in intelligent scaling, cluster awareness, and customization. However, it is often tuned as a one-and-done — whereas your ecosystem and market pricing are constantly changing. 

That’s where Compute Copilot for EKS comes in, constantly tuning your configuration for the best price and availability on autopilot. It allows engineering teams to take advantage of Karpenter’s more effective and granular scaling functionalities, for a fraction of the effort. 

Compute Copilot for EKS ensures you are scheduled on the most cost-optimized and stable option at every moment — automatically updating your provisioning on the fly if not for 50+% EKS savings.

Why Compute Copilot for EKS over legacy Cluster Autoscaler:

Optimizing your AWS costs is a key challenge today. Spot can be cheaper, but terminations pose the threat of outages to your critical workloads. RIs and Savings Plans require risky, long-term commitment and can lead to paying for capacity you don’t need.

Compute Copilot for EKS continuously rightsizes, reconsiders, and re-evaluates your workload placement to available RIs, SPs, or Spot to maximize your savings on autopilot with complete reliability. It is aware of your entire dynamic AWS ecosystem and market pricing in real time. 

Compute Copilot for EKS even covers your commitments with a 100% money-back guarantee. If your usage changes, you change instance regions, or even leave the cloud, we buy back those commitments from you. You get all the cost savings of commitments, with all the flexibility of on-demand. In contrast, Cluster Autoscaler requires much more of your time and labor, lacks Karpenter’s advanced autoscaling automation, and makes you choose between cost savings and flexibility.

Steps to Configure Your EKS Cluster for Cost Optimization and Savings

Install nOps Agent:

  1. Navigate to Compute Copilot → EKS from the nOps dashboard.
  2. Choose the EKS cluster you want to cost-optimize.
  3. Open detail view by clicking on →.
  4. Generate a new API key for nOps Agent. 
  5. Copy the custom command and run it in your command line. 
  6. Test Connectivity of nOps Agent in the Compute Copilot for EKS Dashboard.

Create EC2NodeClass/AWSNodeTemplate:

EC2NodeClass/AWSNodeTemplate can be created in two ways-

i. Auto Configuration

  • For the selected EKS cluster, Select create a EC2NodeClass/AWSNodeTemplate

  • Assign a unique name to it.

  • Choose the AMI Family from the dropdown menu.

  • Add Subnet IDs manually or with Search by tags. 
  • Add Security Group IDs manually or with Search by tags 
  • For EC2NodeClass, you have to select the IAM Role to be used. In case you’re not seeing the desired role in the list, you can manually insert your role name. For AWSNodeTemplate, you have the option to select the InstanceProfile you want or let Karpenter handle the defaulting

  • Configure Metadata Options with user data to give commands after node starts [optional].
  • Create Device Mapping by providing necessary details [optional].
  • Select Create Automatically.

ii. Manual Configuration

  • For the selected EKS cluster, select create a EC2NodeClass/AWSNodeTemplate.

  • Insert the YAML code and validate it. Make sure you specify an unique name under metadata.name property for your resource
  • Now select Create manually.

Create NodePool/Provisioner:

i. Auto Configuration

  • For the selected EKS cluster, select create NodePool/Provisioner.

  • Check Use As Template (Optional, also a cluster may have at most 1 template)

  • Assign a unique NodePool/Provisioner name.

  • Select the created EC2NodeClass/AWSNodeTemplate to pull configuration from.

  • Select Availability Zones.

  • Select Capacity Type — Spot, On Demand or both [recommended to select both]

  • You have the option to select Max Limit of vCPUs & Memory. Using 0 in both fields will indicate Karpenter to apply no limits when allocating resources.

  • Create Taints and Labels if required [for specific provisioner service].

  • For instance selection section, you have the option to filter the types by Architecture, Generation, Accelerator details, Networking, Storage and others. After the filtering is done, you can click Select All Eligible Instance Families for autoselection.

  • Set the weight (optional)

  • Now select Create Automatically.

ii. Manual Configuration

  • For the selected EKS cluster, select create NodePool/Provisioner.

  • Check Use As Template (Optional, also a cluster may have at most 1 template)

  • Insert the YAML code and validate it. Make sure you specify an unique name under metadata.name property for your resource and also add the correct reference to the desired NodeClass under spec.template.spec.nodeClassRef.

  • Now select Create manually.

Use As Base

By checking “Use As Base,” this signals the platform to prioritize On-Demand capacity and prevents underutilization of discount commitments. You can read more about that functionality here.

Test Connectivity

Once the Provisioner is created, the user can again Test Connectivity to confirm that the EKS cluster is configured correctly.

As soon as cluster status displays Configured, Compute Copilot for EKS will start its magic to generate savings on the connected EKS cluster. 

FAQ

  1. Is Karpenter mandatory to install EKS Compute Copilot?
    • Yes, currently EKS Compute Copilot works only if the clusters are being managed by Karpenter. We do have Cluster Autoscaler in our roadmap but it is not available as of now.
  2. Do EKS Compute Copilot Karpenter provisioners take precedence over my own Karpenter provisioners?
    • Yes. Once onboarded to Compute Copilot, the provisioners already existing in the cluster are not going to be used anymore. But you don’t necessarily need to delete them. It’s just that they will not be used while Compute Copilot provisioners are there. Note: It may not always be true depending on the existing provisioners configuration.
  3. Can we import the YAML for existing node templates and provisioners to configure Compute Copilot EKS provisioners?
    • Yes. That is absolutely possible and is shown in the above document within the “Manual Config” steps. By clicking on Manual Config, you can just copy-paste your existing YAML templates to configure nOps Karpenter provisioner
  4. Does nOps provide DevOps support to customers migrating from cluster autoscaler to Karpenter?
    • nOps has experienced engineers who provide free of cost support to all clients to help them with Karpenter migration. You can get as much on-call support as you need to review your Karpenter settings. We also conduct monthly “Karpenter Office Hours” with our existing customer audience to build a community where we can share our experience, customers can ask questions in an open forum, see hands-on to some basic Karpenter implementation practices and much more. However, nOps is not a Service company and therefore, we do not take responsibility for your migration project or provide dedicated DevOps resources or do managed services. Our support is limited to only providing guidance and reviews. Note: If you want a recording of the most recent “Karpenter Office Hours” then please drop us an email on ‘support@nops.io’.
  5. Does nOps Compute Copilot for EKS support configuration of Multiple Provisioners while setting up nOps Karpenter provisioner?
    • Yes, absolutely. Setting up multiple provisioners is a very common thing that customers ask for and we have made it very user friendly to configure that. You get two options to do it, configure in the UI using Auto Config or configure via existing YAML template import using Manual Config method.
  6. I have multiple applications running on the clusters which have different instance requirements, can Compute Copilot support different instance types in such cases?
    • Yes, Compute Copilot does allow you to pick & choose only those instance types that you’d want nOps Karpenter provisioner to provision.
  7. Is it possible to set minimum threshold values for metrics like CPU and Memory while configuring my Karpenter provisioner in Compute Copilot?
    • Yes, we allow users to set the minimum CPU and Memory metrics
  8. Can I put my Stateful workloads on EKS Compute Copilot?
    • EKS Compute Copilot does not come with any limitation on Stateful workloads. However, we do not recommend putting Stateful Workloads on Spot Instances if they are running mission critical operations.
  9. How can I identify resources managed by Compute Copilot EKS?
    • Compute Copilot EKS adds a common tag to all resources it manages. This is accomplished by automatically adding a tag in the spec.tags section of AWSNodeTemplates. The value of the tag is nops:nks:enabled=true and it will appear on all EC2 managed by Compute Copilot EKS.
Managing Karpenter Configurations With nOps IaC support
Managing Resources With Karpenter GitOps Support
Configuring ASGs by Tag
nOps Copilot-Managed ASGs
Compute Copilot For ASG Support Matrix
Onboarding your Autoscaling Groups to nOps Compute Copilot
Onboarding your Autoscaling Groups to nOps Compute Copilot via Stackset
Configure Commitment Management
Compute Copilot for ECS
Onboarding your EKS clusters to Copilot for EKS Cluster Autoscaler
EKS Insights Dashboard
Compute Copilot for EKS - Karpenter Beta Support
Optimizing Commitment Utilization
Compute Copilot Spot Instance Reliability SLA
Commitment Management Permissions
Minimum IAM permissions for the nOps platform
IAM permissions for the nOps platform
IAM permissions for Essentials
Offboarding from the nOps platform
Onboarding AWS Accounts to nOps with Terraform
Onboarding Multiple AWS Linked Accounts with CloudFormation
Service Control Policies
Onboarding AWS with Automatic Setup
Onboarding AWS with 1-click CloudFormation
AWS SSO Integration
Azure SSO Integration
SSO Integration
Okta SSO Integration
OneLogin SSO Integration
Back to top       Home
Tags: copilot