AlbControllerOptions

class aws_cdk.aws_eks.AlbControllerOptions(*, version, additional_helm_chart_values=None, overwrite_service_account=None, policy=None, removal_policy=None, repository=None)

Bases: object

Options for AlbController.

Parameters:
  • version (AlbControllerVersion) – Version of the controller.

  • additional_helm_chart_values (Union[AlbControllerHelmChartOptions, Dict[str, Any], None]) – Additional helm chart values for ALB controller. Default: - no additional helm chart values

  • overwrite_service_account (Optional[bool]) – Overwrite any existing ALB controller service account. If this is set, we will use kubectl apply instead of kubectl create when the ALB controller service account is created. Otherwise, if there is already a service account named ‘aws-load-balancer-controller’ in the kube-system namespace, the operation will fail. Default: false

  • policy (Any) – The IAM policy to apply to the service account. If you’re using one of the built-in versions, this is not required since CDK ships with the appropriate policies for those versions. However, if you are using a custom version, this is required (and validated). Default: - Corresponds to the predefined version.

  • removal_policy (Optional[RemovalPolicy]) – The removal policy applied to the ALB controller resources. The removal policy controls what happens to the resources if they stop being managed by CloudFormation. This can happen in one of three situations: - The resource is removed from the template, so CloudFormation stops managing it - A change to the resource is made that requires it to be replaced, so CloudFormation stops managing it - The stack is deleted, so CloudFormation stops managing all resources in it Default: RemovalPolicy.DESTROY

  • repository (Optional[str]) – The repository to pull the controller image from. Note that the default repository works for most regions, but not all. If the repository is not applicable to your region, use a custom repository according to the information here: https://github.com/kubernetes-sigs/aws-load-balancer-controller/releases. Default: ‘602401143452.dkr.ecr.us-west-2.amazonaws.com/amazon/aws-load-balancer-controller’

ExampleMetadata:

infused

Example:

from aws_cdk.lambda_layer_kubectl_v34 import KubectlV34Layer


eks.Cluster(self, "HelloEKS",
    version=eks.KubernetesVersion.V1_34,
    alb_controller=eks.AlbControllerOptions(
        version=eks.AlbControllerVersion.V2_8_2,
        overwrite_service_account=True
    ),
    kubectl_layer=KubectlV34Layer(self, "kubectl")
)

Attributes

additional_helm_chart_values

Additional helm chart values for ALB controller.

Default:
  • no additional helm chart values

overwrite_service_account

Overwrite any existing ALB controller service account.

If this is set, we will use kubectl apply instead of kubectl create when the ALB controller service account is created. Otherwise, if there is already a service account named ‘aws-load-balancer-controller’ in the kube-system namespace, the operation will fail.

Default:

false

policy

The IAM policy to apply to the service account.

If you’re using one of the built-in versions, this is not required since CDK ships with the appropriate policies for those versions.

However, if you are using a custom version, this is required (and validated).

Default:
  • Corresponds to the predefined version.

removal_policy

The removal policy applied to the ALB controller resources.

The removal policy controls what happens to the resources if they stop being managed by CloudFormation. This can happen in one of three situations:

  • The resource is removed from the template, so CloudFormation stops managing it

  • A change to the resource is made that requires it to be replaced, so CloudFormation stops managing it

  • The stack is deleted, so CloudFormation stops managing all resources in it

Default:

RemovalPolicy.DESTROY

repository

The repository to pull the controller image from.

Note that the default repository works for most regions, but not all. If the repository is not applicable to your region, use a custom repository according to the information here: https://github.com/kubernetes-sigs/aws-load-balancer-controller/releases.

Default:

‘602401143452.dkr.ecr.us-west-2.amazonaws.com/amazon/aws-load-balancer-controller’

version

Version of the controller.