CDK construct library that allows you install Karpenter in an AWS EKS cluster
Project description
cdk-eks-karpenter
This construct configures the necessary dependencies and installs Karpenter on an EKS cluster managed by AWS CDK.
Prerequisites
Usage with EC2 Spot Capacity
If you have not used EC2 spot in your AWS account before, follow the instructions here to create the service linked role in your account allowing Karpenter to provision EC2 Spot Capacity.
Using
In your CDK project, initialize a new Karpenter construct for your EKS cluster, like this:
const cluster = new Cluster(this, 'testCluster', {
vpc: vpc,
role: clusterRole,
version: KubernetesVersion.V1_27,
defaultCapacity: 1
});
const karpenter = new Karpenter(this, 'Karpenter', {
cluster: cluster,
namespace: "kube-system"
});
This will install and configure Karpenter in your cluster. To have Karpenter do something useful, you also need to create an EC2NodeClass and an NodePool, for a more complete example, see test/integ.karpenter.ts.
Known issues
It is now a best practice to install Karpenter into the kube-system namespace:
Kapenter CRD webhooks have 'kube-system' hard-coded into them, and do not work in other namespaces (such as 'karpenter')
Versions earlier than v0.6.1 fails to install
As of aws/karpenter#1145 the Karpenter Helm chart is
refactored to specify clusterEndpoint and clusterName on the root level of the chart values, previously
these values was specified under the key controller.
Testing
This construct adds a custom task to projen, so you can test a full deployment
of an EKS cluster with Karpenter installed as specified in test/integ.karpenter.ts by running the
following:
export CDK_DEFAULT_REGION=<aws region>
export CDK_DEFAULT_ACCOUNT=<account id>
npx projen test:deploy
As the above will create a cluster without EC2 capacity, with CoreDNS and Karpenter running as Fargate pods, you can test out the functionality of Karpenter by deploying an inflation deployment, which will spin up a number of pods that will trigger Karpenter creation of worker nodes:
kubectl apply -f test/inflater-deployment.yml
You can clean things up by deleting the deployment and the CDK test stack:
kubectl delete -f test/inflater-deployment.yml
npx projen test:destroy
FAQ
I'm not able to launch spot instances
- Ensure you have the appropriate linked role available in your account, for more details, see the karpenter documentation
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file cdk_eks_karpenter-1.0.19.tar.gz.
File metadata
- Download URL: cdk_eks_karpenter-1.0.19.tar.gz
- Upload date:
- Size: 85.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.14.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
244161212b4c68bcb7a9247752a7133d875450a1d7b20ea7fc0d517c84fb24da
|
|
| MD5 |
8b4d7b8eb903ac31930909d0ca0d7b64
|
|
| BLAKE2b-256 |
af5599a498c3bf756381136970acaaac7ef04ab5feda0d406a7607807a7518bf
|
File details
Details for the file cdk_eks_karpenter-1.0.19-py3-none-any.whl.
File metadata
- Download URL: cdk_eks_karpenter-1.0.19-py3-none-any.whl
- Upload date:
- Size: 84.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.14.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
50e386376b55d42e0b18fafee478c338ec35a942da3c2292f1e9c59789bfed9f
|
|
| MD5 |
b8d9466347ad957676411f31a33fc332
|
|
| BLAKE2b-256 |
ea35d03367c9cbef137acf3bd30c398f9104b74a5625fe0dce8c8462918a742c
|