Interface NodegroupOptions
- All Superinterfaces:
software.amazon.jsii.JsiiSerializable
- All Known Subinterfaces:
NodegroupProps
- All Known Implementing Classes:
NodegroupOptions.Jsii$Proxy
,NodegroupProps.Jsii$Proxy
Example:
Cluster cluster; cluster.addNodegroupCapacity("extra-ng-spot", NodegroupOptions.builder() .instanceTypes(List.of( new InstanceType("c5.large"), new InstanceType("c5a.large"), new InstanceType("c5d.large"))) .minSize(3) .capacityType(CapacityType.SPOT) .build());
-
Nested Class Summary
Modifier and TypeInterfaceDescriptionstatic final class
A builder forNodegroupOptions
static final class
An implementation forNodegroupOptions
-
Method Summary
Modifier and TypeMethodDescriptionstatic NodegroupOptions.Builder
builder()
default NodegroupAmiType
The AMI type for your node group.default CapacityType
The capacity type of the nodegroup.default Number
The current number of worker nodes that the managed node group should maintain.default Number
The root device disk size (in GiB) for your node group instances.default Boolean
Force the update if the existing node group's pods are unable to be drained due to a pod disruption budget issue.default List<InstanceType>
The instance types to use for your node group.The Kubernetes labels to be applied to the nodes in the node group when they are created.default LaunchTemplateSpec
Launch template specification used for the nodegroup.default Number
The maximum number of worker nodes that the managed node group can scale out to.default Number
The maximum number of nodes unavailable at once during a version update.default Number
The maximum percentage of nodes unavailable during a version update.default Number
The minimum number of worker nodes that the managed node group can scale in to.default String
Name of the Nodegroup.default IRole
The IAM role to associate with your node group.default String
The AMI version of the Amazon EKS-optimized AMI to use with your node group (for example,1.14.7-YYYYMMDD
).default NodegroupRemoteAccess
The remote access (SSH) configuration to use with your node group.default SubnetSelection
The subnets to use for the Auto Scaling group that is created for your node group.getTags()
The metadata to apply to the node group to assist with categorization and organization.The Kubernetes taints to be applied to the nodes in the node group when they are created.Methods inherited from interface software.amazon.jsii.JsiiSerializable
$jsii$toJson
-
Method Details
-
getAmiType
The AMI type for your node group.If you explicitly specify the launchTemplate with custom AMI, do not specify this property, or the node group deployment will fail. In other cases, you will need to specify correct amiType for the nodegroup.
Default: - auto-determined from the instanceTypes property when launchTemplateSpec property is not specified
-
getCapacityType
The capacity type of the nodegroup.Default: - ON_DEMAND
-
getDesiredSize
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
-
getDiskSize
The root device disk size (in GiB) for your node group instances.Default: 20
-
getForceUpdate
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
-
getInstanceTypes
The instance types to use for your node group.Default: t3.medium will be used according to the cloudformation document.
- See Also:
-
getLabels
The Kubernetes labels to be applied to the nodes in the node group when they are created.Default: - None
-
getLaunchTemplateSpec
Launch template specification used for the nodegroup.Default: - no launch template
- See Also:
-
getMaxSize
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
-
getMinSize
The minimum number of worker nodes that the managed node group can scale in to.This number must be greater than or equal to zero.
Default: 1
-
getNodegroupName
Name of the Nodegroup.Default: - resource ID
-
getNodeRole
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.
-
getReleaseVersion
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.
-
getRemoteAccess
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
-
getSubnets
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 ofshared
, whereCLUSTER_NAME
is replaced with the name of your cluster.Default: - private subnets
-
getTags
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
-
getTaints
The Kubernetes taints to be applied to the nodes in the node group when they are created.Default: - None
-
builder
- Returns:
- a
NodegroupOptions.Builder
ofNodegroupOptions
-