-
Notifications
You must be signed in to change notification settings - Fork 85
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
905122a
commit bf2f311
Showing
1 changed file
with
93 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,93 @@ | ||
|
||
# Karpenter | ||
|
||
Karpenter is an open-source Kubernetes cluster autoscaler built for efficiency and speed. This Helm chart installs Karpenter in your Kubernetes cluster and can be used to manage your node pools for dynamically scaling your infrastructure. This chart supports automated deployment of Karpenter, including the creation of NodePools, EC2NodeClasses, IAM roles, and other necessary resources. | ||
|
||
To install Karpenter, use the following commands: | ||
|
||
```shell | ||
$ helm repo add ot-helm https://ot-container-kit.github.io/helm-charts/ | ||
$ helm install karpenter ot-helm/karpenter --namespace kube-system | ||
``` | ||
|
||
To upgrade the setup: | ||
|
||
```shell | ||
$ helm upgrade karpenter ot-helm/karpenter --install --namespace kube-system | ||
``` | ||
|
||
To uninstall the chart: | ||
|
||
```shell | ||
$ helm delete karpenter --namespace kube-system | ||
``` | ||
|
||
### Pre-Requisites | ||
|
||
- Kubernetes => 1.18+ | ||
- Helm => 3.X | ||
- Karpenter Operator => 0.1.0 | ||
- IAM Roles for Karpenter | ||
- Add tags to subnets and security groups | ||
- Update aws-auth ConfigMap | ||
|
||
### Parameters | ||
|
||
| **Name** | **Value** | **Description** | | ||
|--------------------------------------------------------------------|:-------------------------------|------------------------------------------------| | ||
| `karpenter.settings.clusterName` | `my-cluster` | The name of your Kubernetes cluster | | ||
| `karpenter.serviceAccount.annotations.eks.amazonaws.com/role-arn` | Required | IAM role ARN for Karpenter controller | | ||
| `karpenter.controller.resources.requests.cpu` | `1` | CPU request for Karpenter controller | | ||
| `karpenter.controller.resources.requests.memory` | `1Gi` | Memory request for Karpenter controller | | ||
| `karpenter.controller.resources.limits.cpu` | `1` | CPU limit for Karpenter controller | | ||
| `karpenter.controller.resources.limits.memory` | `1Gi` | Memory limit for Karpenter controller | | ||
| `nodePools` | [] | List of NodePools to be created | | ||
| `nodePools.name` | default-nodepool | Name of the NodePool | | ||
| `nodePools.labels` - If not required can be omiited | {} | Labels for the NodePool | | ||
| `nodePools.annotations` - If not required can be omiited | {} | Annotations for the NodePool | | ||
| `nodePools.requirements` - Can be empty [] | [] | Node requirements like CPU, memory, etc. | | ||
| `nodePools.taints` - If not required can be omiited | [] | Taints for the NodePool | | ||
| `nodePools.expireAfter` | 720h | Expiration duration for idle NodePools | | ||
| `nodePools.limits.cpu` | "1000m" | CPU limit for the NodePool | | ||
| `nodePools.limits.memory`- If not required can be omiited | "2Gi" | Memory limit for the NodePool | | ||
| `nodePools.disruption.consolidationPolicy` | WhenEmptyOrUnderutilized | Consolidation policy for underutilized nodes | | ||
| `nodePools.disruption.consolidateAfter` | 1m | Time before consolidating underutilized nodes | | ||
|
||
### Example `values.yaml` | ||
|
||
```yaml | ||
nodePools: | ||
- name: default-nodepool | ||
labels: | ||
environment: production | ||
annotations: | ||
dedicated: true | ||
requirements: | ||
- key: "kubernetes.io/arch" | ||
operator: "In" | ||
values: | ||
- amd64 | ||
taints: | ||
- key: "dedicated" | ||
value: "true" | ||
effect: "NoSchedule" | ||
nodeClass: | ||
group: karpenter.k8s.aws | ||
kind: EC2NodeClass | ||
name: default | ||
expireAfter: 720h | ||
limits: | ||
cpu: "1000m" | ||
memory: "2Gi" | ||
disruption: | ||
consolidationPolicy: "WhenEmptyOrUnderutilized" | ||
consolidateAfter: "1m" | ||
``` | ||
This `values.yaml` example deploys a Karpenter setup with a NodePool named `default-nodepool`, containing specifications such as labels, annotations, requirements, taints, node class, and limits. | ||
|
||
### Notes: | ||
|
||
- Karpenter automatically creates and manages NodePools as part of the installation process. | ||
- Make sure to configure the IAM roles required by Karpenter for it to interact with EC2 instances and manage resources along with all prerequisites. | ||
- The chart will ensure the Karpenter controller and NodePools are deployed correctly with all required configurations. |