NodegroupProps

class aws_cdk.aws_eks.NodegroupProps(*, ami_type=None, desired_size=None, disk_size=None, force_update=None, instance_type=None, labels=None, launch_template_spec=None, max_size=None, min_size=None, nodegroup_name=None, node_role=None, release_version=None, remote_access=None, subnets=None, tags=None, cluster)

Bases: aws_cdk.aws_eks.NodegroupOptions

(experimental) NodeGroup properties interface.

Parameters
  • ami_type (Optional[NodegroupAmiType]) – (experimental) The AMI type for your node group. Default: - auto-determined from the instanceType property.

  • desired_size (Union[int, float, None]) – (experimental) The current number of worker nodes that the managed node group should maintain. If not specified, the nodewgroup will initially create minSize instances. Default: 2

  • disk_size (Union[int, float, None]) – (experimental) The root device disk size (in GiB) for your node group instances. Default: 20

  • force_update (Optional[bool]) – (experimental) Force the update if the existing node group’s pods are unable to be drained due to a pod disruption budget issue. If an update fails because pods could not be drained, you can force the update after it fails to terminate the old node whether or not any pods are running on the node. Default: true

  • instance_type (Optional[InstanceType]) – (experimental) The instance type to use for your node group. Currently, you can specify a single instance type for a node group. The default value for this parameter is t3.medium. If you choose a GPU instance type, be sure to specify the AL2_x86_64_GPU with the amiType parameter. Default: t3.medium

  • labels (Optional[Mapping[str, str]]) – (experimental) The Kubernetes labels to be applied to the nodes in the node group when they are created. Default: - None

  • launch_template_spec (Optional[LaunchTemplateSpec]) – (experimental) Launch template specification used for the nodegroup. Default: - no launch template

  • max_size (Union[int, float, None]) – (experimental) The maximum number of worker nodes that the managed node group can scale out to. Managed node groups can support up to 100 nodes by default. Default: - desiredSize

  • min_size (Union[int, float, None]) – (experimental) The minimum number of worker nodes that the managed node group can scale in to. This number must be greater than zero. Default: 1

  • nodegroup_name (Optional[str]) – (experimental) Name of the Nodegroup. Default: - resource ID

  • node_role (Optional[IRole]) – (experimental) The IAM role to associate with your node group. The Amazon EKS worker node kubelet daemon makes calls to AWS APIs on your behalf. Worker nodes receive permissions for these API calls through an IAM instance profile and associated policies. Before you can launch worker nodes and register them into a cluster, you must create an IAM role for those worker nodes to use when they are launched. Default: - None. Auto-generated if not specified.

  • release_version (Optional[str]) – (experimental) The AMI version of the Amazon EKS-optimized AMI to use with your node group (for example, 1.14.7-YYYYMMDD). Default: - The latest available AMI version for the node group’s current Kubernetes version is used.

  • remote_access (Optional[NodegroupRemoteAccess]) – (experimental) The remote access (SSH) configuration to use with your node group. Disabled by default, however, if you specify an Amazon EC2 SSH key but do not specify a source security group when you create a managed node group, then port 22 on the worker nodes is opened to the internet (0.0.0.0/0) Default: - disabled

  • subnets (Optional[SubnetSelection]) – (experimental) The subnets to use for the Auto Scaling group that is created for your node group. By specifying the SubnetSelection, the selected subnets will automatically apply required tags i.e. kubernetes.io/cluster/CLUSTER_NAME with a value of shared, where CLUSTER_NAME is replaced with the name of your cluster. Default: - private subnets

  • tags (Optional[Mapping[str, str]]) – (experimental) The metadata to apply to the node group to assist with categorization and organization. Each tag consists of a key and an optional value, both of which you define. Node group tags do not propagate to any other resources associated with the node group, such as the Amazon EC2 instances or subnets. Default: - None

  • cluster (ICluster) – (experimental) Cluster resource.

Stability

experimental

Attributes

ami_type

(experimental) The AMI type for your node group.

Default
  • auto-determined from the instanceType property.

Stability

experimental

Return type

Optional[NodegroupAmiType]

cluster

(experimental) Cluster resource.

Stability

experimental

Return type

ICluster

desired_size

(experimental) The current number of worker nodes that the managed node group should maintain.

If not specified, the nodewgroup will initially create minSize instances.

Default

2

Stability

experimental

Return type

Union[int, float, None]

disk_size

(experimental) The root device disk size (in GiB) for your node group instances.

Default

20

Stability

experimental

Return type

Union[int, float, None]

force_update

(experimental) Force the update if the existing node group’s pods are unable to be drained due to a pod disruption budget issue.

If an update fails because pods could not be drained, you can force the update after it fails to terminate the old node whether or not any pods are running on the node.

Default

true

Stability

experimental

Return type

Optional[bool]

instance_type

(experimental) The instance type to use for your node group.

Currently, you can specify a single instance type for a node group. The default value for this parameter is t3.medium. If you choose a GPU instance type, be sure to specify the AL2_x86_64_GPU with the amiType parameter.

Default

t3.medium

Stability

experimental

Return type

Optional[InstanceType]

labels

(experimental) The Kubernetes labels to be applied to the nodes in the node group when they are created.

Default
  • None

Stability

experimental

Return type

Optional[Mapping[str, str]]

launch_template_spec

(experimental) Launch template specification used for the nodegroup.

Default
  • no launch template

See
Stability

experimental

Return type

Optional[LaunchTemplateSpec]

max_size

(experimental) The maximum number of worker nodes that the managed node group can scale out to.

Managed node groups can support up to 100 nodes by default.

Default
  • desiredSize

Stability

experimental

Return type

Union[int, float, None]

min_size

(experimental) The minimum number of worker nodes that the managed node group can scale in to.

This number must be greater than zero.

Default

1

Stability

experimental

Return type

Union[int, float, None]

node_role

(experimental) The IAM role to associate with your node group.

The Amazon EKS worker node kubelet daemon makes calls to AWS APIs on your behalf. Worker nodes receive permissions for these API calls through an IAM instance profile and associated policies. Before you can launch worker nodes and register them into a cluster, you must create an IAM role for those worker nodes to use when they are launched.

Default
  • None. Auto-generated if not specified.

Stability

experimental

Return type

Optional[IRole]

nodegroup_name

(experimental) Name of the Nodegroup.

Default
  • resource ID

Stability

experimental

Return type

Optional[str]

release_version

(experimental) The AMI version of the Amazon EKS-optimized AMI to use with your node group (for example, 1.14.7-YYYYMMDD).

Default
  • The latest available AMI version for the node group’s current Kubernetes version is used.

Stability

experimental

Return type

Optional[str]

remote_access

(experimental) The remote access (SSH) configuration to use with your node group.

Disabled by default, however, if you specify an Amazon EC2 SSH key but do not specify a source security group when you create a managed node group, then port 22 on the worker nodes is opened to the internet (0.0.0.0/0)

Default
  • disabled

Stability

experimental

Return type

Optional[NodegroupRemoteAccess]

subnets

(experimental) The subnets to use for the Auto Scaling group that is created for your node group.

By specifying the SubnetSelection, the selected subnets will automatically apply required tags i.e. kubernetes.io/cluster/CLUSTER_NAME with a value of shared, where CLUSTER_NAME is replaced with the name of your cluster.

Default
  • private subnets

Stability

experimental

Return type

Optional[SubnetSelection]

tags

(experimental) The metadata to apply to the node group to assist with categorization and organization.

Each tag consists of a key and an optional value, both of which you define. Node group tags do not propagate to any other resources associated with the node group, such as the Amazon EC2 instances or subnets.

Default
  • None

Stability

experimental

Return type

Optional[Mapping[str, str]]