KubernetesManifestProps
- class aws_cdk.aws_eks.KubernetesManifestProps(*, ingress_alb=None, ingress_alb_scheme=None, prune=None, removal_policy=None, skip_validation=None, cluster, manifest, overwrite=None)
Bases:
KubernetesManifestOptionsProperties for KubernetesManifest.
- Parameters:
ingress_alb (
Optional[bool]) – Automatically detectIngressresources in the manifest and annotate them so they are picked up by an ALB Ingress Controller. Default: falseingress_alb_scheme (
Optional[AlbScheme]) – Specify the ALB scheme that should be applied toIngressresources. Only applicable ifingressAlbis set totrue. Default: AlbScheme.INTERNALprune (
Optional[bool]) – When a resource is removed from a Kubernetes manifest, it no longer appears in the manifest, and there is no way to know that this resource needs to be deleted. To address this,kubectl applyhas a--pruneoption which will query the cluster for all resources with a specific label and will remove all the labeld resources that are not part of the applied manifest. If this option is disabled and a resource is removed, it will become “orphaned” and will not be deleted from the cluster. When this option is enabled (default), the construct will inject a label to all Kubernetes resources included in this manifest which will be used to prune resources when the manifest changes viakubectl apply --prune. The label name will beaws.cdk.eks/prune-<ADDR>where<ADDR>is the 42-char unique address of this construct in the construct tree. Value is empty. Default: - based on the prune option of the cluster, which istrueunless otherwise specified.removal_policy (
Optional[RemovalPolicy]) – The removal policy applied to the custom resource that manages the Kubernetes manifest. The removal policy controls what happens to the resource if it stops 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.DESTROYskip_validation (
Optional[bool]) – A flag to signify if the manifest validation should be skipped. Default: falsecluster (
ICluster) – The EKS cluster to apply this manifest to. [disable-awslint:ref-via-interface]manifest (
Sequence[Mapping[str,Any]]) – The manifest to apply. Consists of any number of child resources. When the resources are created/updated, this manifest will be applied to the cluster throughkubectl applyand when the resources or the stack is deleted, the resources in the manifest will be deleted throughkubectl delete.overwrite (
Optional[bool]) – Overwrite any existing resources. If this is set, we will usekubectl applyinstead ofkubectl createwhen the resource is created. Otherwise, if there is already a resource in the cluster with the same name, the operation will fail. Default: false
- ExampleMetadata:
infused
Example:
# cluster: eks.Cluster app_label = {"app": "hello-kubernetes"} deployment = { "api_version": "apps/v1", "kind": "Deployment", "metadata": {"name": "hello-kubernetes"}, "spec": { "replicas": 3, "selector": {"match_labels": app_label}, "template": { "metadata": {"labels": app_label}, "spec": { "containers": [{ "name": "hello-kubernetes", "image": "paulbouwer/hello-kubernetes:1.5", "ports": [{"container_port": 8080}] } ] } } } } service = { "api_version": "v1", "kind": "Service", "metadata": {"name": "hello-kubernetes"}, "spec": { "type": "LoadBalancer", "ports": [{"port": 80, "target_port": 8080}], "selector": app_label } } # option 1: use a construct eks.KubernetesManifest(self, "hello-kub", cluster=cluster, manifest=[deployment, service] ) # or, option2: use `addManifest` cluster.add_manifest("hello-kub", service, deployment)
Attributes
- cluster
The EKS cluster to apply this manifest to.
[disable-awslint:ref-via-interface]
- ingress_alb
Automatically detect
Ingressresources in the manifest and annotate them so they are picked up by an ALB Ingress Controller.- Default:
false
- ingress_alb_scheme
Specify the ALB scheme that should be applied to
Ingressresources.Only applicable if
ingressAlbis set totrue.- Default:
AlbScheme.INTERNAL
- manifest
The manifest to apply.
Consists of any number of child resources.
When the resources are created/updated, this manifest will be applied to the cluster through
kubectl applyand when the resources or the stack is deleted, the resources in the manifest will be deleted throughkubectl delete.Example:
[{ "api_version": "v1", "kind": "Pod", "metadata": {"name": "mypod"}, "spec": { "containers": [{"name": "hello", "image": "paulbouwer/hello-kubernetes:1.5", "ports": [{"container_port": 8080}]}] } }]
- overwrite
Overwrite any existing resources.
If this is set, we will use
kubectl applyinstead ofkubectl createwhen the resource is created. Otherwise, if there is already a resource in the cluster with the same name, the operation will fail.- Default:
false
- prune
When a resource is removed from a Kubernetes manifest, it no longer appears in the manifest, and there is no way to know that this resource needs to be deleted.
To address this,
kubectl applyhas a--pruneoption which will query the cluster for all resources with a specific label and will remove all the labeld resources that are not part of the applied manifest. If this option is disabled and a resource is removed, it will become “orphaned” and will not be deleted from the cluster.When this option is enabled (default), the construct will inject a label to all Kubernetes resources included in this manifest which will be used to prune resources when the manifest changes via
kubectl apply --prune.The label name will be
aws.cdk.eks/prune-<ADDR>where<ADDR>is the 42-char unique address of this construct in the construct tree. Value is empty.- Default:
based on the prune option of the cluster, which is
trueunless
otherwise specified.
- removal_policy
The removal policy applied to the custom resource that manages the Kubernetes manifest.
The removal policy controls what happens to the resource if it stops 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
- skip_validation
A flag to signify if the manifest validation should be skipped.
- Default:
false