Skip to content

Add-ons

The eks-blueprints framework leverages a modular approach to managing Add-ons that run within the context of a Kubernetes cluster. Customers are free to select the add-ons that run in each of their blueprint clusters.

Within the context of the eks-blueprints framework, an add-on is abstracted as ClusterAddOn interface, and the implementation of the add-on interface can do whatever is necessary to support the desired add-on functionality. This can include applying manifests to a Kubernetes cluster or calling AWS APIs to provision new resources.

Here's an improved version of the public documentation abstract with enhanced readability:

Add-on Dependencies and Ordering in EKS Blueprints

Add-ons in EKS Blueprints rely on CDK/CloudFormation constructs for provisioning. By default, these constructs don't guarantee a specific order unless explicitly defined using the CDK dependency mechanism.

Default Behavior - Add-ons without explicit dependencies are provisioned concurrently in an arbitrary order. - The order in which you add add-ons to the blueprint may not matter if there are no explicit dependencies between them.

Lack of explicit dependencies can lead to: - Race conditions - Non-deterministic behavior - Difficult-to-troubleshoot problems

For example, if an add-on requires the AWS LoadBalancer Controller to be in place, but there's no explicit dependency, the dependent add-on might start installing before the ALB controller is fully provisioned.

Built-in Dependencies

Many add-ons in EKS Blueprints have pre-defined dependencies. For example, Istio* add-ons depend on IstioBase, AmpAddOn depends on AdotCollectorAddOn, etc.

These dependencies are implemented using the @dependable decorator applied to the deploy method of the dependent add-on:

export class AmpAddOn implements ClusterAddOn {
    @dependable(AdotCollectorAddOn.name)
    deploy(clusterInfo: ClusterInfo): Promise<Construct> {
        // Implementation
    }
}

Custom Ordering

For cases where the framework doesn't capture all necessary dependencies, you have two options:

  1. Subclass an add-on and override the deploy method to declare additional dependencies.
  2. Use the EKS Blueprints framework's mechanism to create dependencies at the project level.

Creating Dependencies at the Project Level

To ensure one add-on is installed before another:

  1. Ensure the prerequisite add-on is added to the blueprint ahead of the dependent add-ons.
  2. Mark the prerequisite add-on as "strictly ordered" using:
Reflect.defineMetadata("ordered", true, blueprints.addons.PrerequisiteAddOn);

This ensures that all add-ons declared after the marked add-on will only be provisioned after it's successfully deployed.

Example

// Enable detailed logging
blueprints.utils.logger.settings.minLevel = 1;

// Mark AwsLoadBalancerControllerAddOn as requiring strict ordering
Reflect.defineMetadata("ordered", true, blueprints.addons.AwsLoadBalancerControllerAddOn);

blueprints.EksBlueprint.builder()
    .addOns(new VpcCniAddon) // add all add-ons that do NOT need to depend on ALB before the ALB add-on
    .addOns(new AwsLoadBalancerControllerAddOn())
    .addOns(new MyAddOn()) // Automatically depends on AwsLoadBalancerControllerAddOn
    .build(...);

Note: You can mark multiple add-ons as ordered if needed.

Supported Add-ons

The framework currently supports the following add-ons.

Addon Description x86_64/amd64 arm64
ACKAddOn Adds ACK (AWS Controllers for Kubernetes .
AdotAddOn Adds AWS Distro for OpenTelemetry (ADOT) Operator.
AmpAdotAddOn Deploys ADOT Collector for Prometheus to remote write metrics from AMP.
AppMeshAddOn Adds an AppMesh controller and CRDs.
ApacheAirflowAddOn This add-on is an implementation of Apache Airflow on EKS using the official helm chart.
ArgoCDAddOn Provisions Argo CD into your cluster.
AWS Batch for EKS Enables EKS cluster to be used with AWS Batch on EKS
AWS CloudWatch Insgihts Provisions CloudWatch Insights to be used with the EKS cluster.
AWS for Fluent Bit Provisions Fluent Bit into your cluster for log aggregation and consumption.
AWS Load Balancer Controller Provisions the AWS Load Balancer Controller into your cluster.
AWS Node Termination Handler Provisions Node Termination Handler into your cluster.
AWS Private CA Issuer Installs AWS Private CA Issuer into your cluster.
Backstage Installs Backstage.
CertManagerAddOn Adds Certificate Manager to your EKS cluster.
CalicoOperatorAddOn Adds the Calico CNI/Network policy cluster.
CloudWatchAdotAddOn Adds Cloudwatch exporter based on ADOT operator integrating monitoring with CloudWatch.
CloudWatchLogsAddOn Adds AWS for Fluent Bit to the cluster that exports logs to CloudWatch.
ClusterAutoscalerAddOn Adds the standard cluster autoscaler.
ContainerInsightsAddOn Adds support for container insights.
CoreDnsAddOn Adds CoreDNS Amazon EKS add-on. CoreDNS is a flexible, extensible DNS server that can serve as the Kubernetes cluster DNS.
DatadogAddOn Adds Datadog Amazon EKS add-on. Datadog is the monitoring and security platform for cloud applications.
Dynatrace Adds the Dynatrace OneAgent Operator.
EbsCsiDriverAddOn Adds EBS CSI Driver Amazon EKS add-on. This driver manages the lifecycle of Amazon EBS volumes for persistent storage.
EfsCsiDriverAddOn Adds EFS CSI Driver Amazon EKS add-on. This driver manages the lifecycle of Amazon EFS volumes for persistent storage.
EmrOnEksAddOn Enable EKS cluster to be used with EMR on EKS
ExternalDnsAddOn Adds External DNS support for AWS to the cluster, integrating with Amazon Route 53.
ExternalSecretsAddOn Adds External Secrets Operator to the cluster.
FluxcdAddOn Setting up Fluxcd to manage one or more Kubernetes clusters.
GpuOperatorAddon Deploys NVIDIA GPU Operator on your EKS Cluster to manage configuration of drivers and software dependencies for GPU instances
GrafanaOperatorAddon Deploys GrafanaOperatorAddon on your EKS Cluster to manage Amazon Managed Grafana and other external Grafana instances.
IngressNginxAddOn Adds Kubernetes NGINX ingress controller
IstioBaseAddOn Adds support for Istio base chart to the EKS cluster.
InstanaAddOn Adds the IBM® Instana® Agent Operator to the EKS cluster.
IstioControlPlaneAddOn Installs Istio Control Plane addon to the EKS cluster.
IstioCniAddOn Installs Istio Cni Plugin addon to the EKS cluster.
IstioIngressGatewayAddOn Installs Istio Ingress Gateway Plugin to the EKS cluster.
JupyterHubAddOn Adds JupyterHub support for AWS to the cluster.
Kasten-K10AddOn Kasten K10 add-on installs Kasten K10 into your Amazon EKS cluster.
KedaAddOn Installs Keda into EKS cluster.
Keptn Keptn Control Plane and Execution Plane AddOn.
KnativeAddOn Deploys the KNative Operator to ease setting up the rest of KNatives CRDs
KomodorAddOn Adds the Komodor Agent to the EKS Cluster.
KonveyorAddOn Adds Konveyor to the EKS Cluster.
KubecostAddOn Adds Kubecost cost analyzer to the EKS cluster.
KubeflowAddOn Adds kubeflow Kubeflow pipeline addon the EKS cluster.
KubeRayAddOn Installs the KubeRay Operator.
KubeviousAddOn Adds Kubevious open source Kubernetes dashboard to an EKS cluster.
KarpenterAddOn Adds Karpenter support for Amazon EKS.
KubeProxyAddOn Adds kube-proxy Amazon EKS add-on. Kube-proxy maintains network rules on each Amazon EC2 node.
KubeStateMetricsAddOn Adds kube-state-metrics into the EKS cluster.
KubesharkAddOn Deep visibility and monitoring of all API traffic
MetricsServerAddOn Adds metrics server (pre-req for HPA and other monitoring tools).
NewRelicAddOn Adds New Relic and Pixie observability for Amazon EKS.
NginxAddOn Adds NGINX ingress controller
NeuronDevicePluginAddOn Adds Neuron Device Plugin Addon
NeuronMonitorAddOn Adds Neuron Monitor Addon
OpaGatekeeperAddOn Adds OPA Gatekeeper
ParalusAddOn Adds Paralus
PixieAddOn Adds Pixie to the EKS Cluster. Pixie provides auto-telemetry for requests, metrics, application profiles, and more.
PrometheusNodeExporterAddOn Adds prometheus-node-exporter to the EKS Cluster. Prometheus Node Exporter enables you to measure various machine resources such as memory, disk and CPU utilization.
Rafay Adds Rafay’s Kubernetes Operations Platform (KOP) to the EKS Cluster. Rafay allows you to deploy, operate, and manage the lifecycle of Kubernetes clusters
SecretsStoreAddOn Adds AWS Secrets Manager and Config Provider for Secret Store CSI Driver to the EKS Cluster.
Snyk Adds the Snyk Monitor to the EKS Cluster.
SSMAgentAddOn Adds Amazon SSM Agent to worker nodes.
UpboundUniversalCrossplaneAddOn Allows Elastic Kubernetes Service (Amazon EKS) clusters to manage the lifecycle of Crossplane distribution.
VpcCniAddOn Adds the Amazon VPC CNI Amazon EKS addon to support native VPC networking for Amazon EKS.
VeleroAddOn Adds Velero to the EKS Cluster.
XrayAddOn Adds XRay Daemon to the EKS Cluster. NA NA
XrayAdotAddOn Deploys ADOT Collector for Xray to receive traces from your workloads.
~~GmaestroAddOn~~ Deprecated due to EOL. Adds gMaestro cost optimization solution for EKS cluster.
EksPodIdentityAgentAddOn Setting up the EKS Pod Identity Agent

Standard Helm Add-On Configuration Options

Many add-ons leverage helm to provision and maintain deployments. All provided add-ons that leverage helm allow specifying the following add-on attributes:

    /**
     * Name of the helm chart (add-on)
     */
    name?: string,

    /**
     * Namespace where helm release will be installed
     */
    namespace?: string,

    /**
     * Chart name
     */
    chart?: string,

    /**
     * Helm chart version.
     */
    version?: string,

    /**
     * Helm release
     */
    release?: string,

    /**
     * Helm repository
     */
    repository?: string,

    /**
     * When global helm version validation is enabled with HelmAddOn.validateHelmVersions = true
     * allows to skip validation for a particular helm add-on. 
     */
    skipVersionValidation?: boolean,

    /**
     * Optional values for the helm chart.
     */
    values?: Values

Ability to set repository url may be leveraged for private repositories.

Version field can be modified from the default chart version, e.g. if the add-on should be upgraded to the desired version, however, since the helm chart version supplied by the customer may not have been tested as part of the Blueprints release process, Blueprints community may not be able to reproduce/fix issues related to the helm chart version upgrade.

Helm Version Validation

All add-ons that derive from HelmAddOn support optional version validation against the latest published version in the target helm repository.

Helm version validation can result either in a warning on console during list, synth and deploy operations or an exception if the target helm repository contains higher version than the one leveraged in the add-on.

Example output:

INFO  Chart argo-cd-4.9.12 is at the latest version. 
INFO  Chart external-dns-6.6.0 is at the latest version. 
WARN Upgrade is needed for chart gatekeeper-3.8.1: latest version is 3.9.0-beta.2. 
INFO  Chart appmesh-controller-1.5.0 is at the latest version. 
INFO  Chart tigera-operator-v3.23.2 is at the latest version. 
WARN Upgrade is needed for chart adot-exporter-for-eks-on-ec2-0.1.0: latest version is 0.6.0. 
INFO  Chart aws-load-balancer-controller-1.4.2 is at the latest version. 
INFO  Chart nginx-ingress-0.14.0 is at the latest version. 
INFO  Chart velero-2.30.1 is at the latest version. 
INFO  Chart falco-1.19.4 is at the latest version. 
WARN Upgrade is needed for chart karpenter-0.13.1: latest version is 0.13.2. 
INFO  Chart kubevious-1.0.10 is at the latest version. 
INFO  Chart aws-efs-csi-driver-2.2.7 is at the latest version. 
INFO  Chart keda-2.7.2 is at the latest version. 
INFO  Chart secrets-store-csi-driver-1.2.1 is at the latest version. 
  • Enable/Disable Helm version validation globally
import { HelmAddOn } from '@aws-quickstart/eks-blueprints';

HelmAddOn.validateHelmVersions = true; // by default will print out warnings
HelmAddOn.failOnVersionValidation = true; // enable synth to throw exceptions on validation check failures
  • Enable/Disable Helm version validation per add-on
new blueprints.addons.MetricsServerAddOn({
    skipVersionValidation: true
})