Class ManagedClusterAgentPoolProfile
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionname()Get the name property: Unique name of the agent pool profile in the context of the subscription and resource group.voidvalidate()Validates the instance.withAvailabilityZones(List<String> availabilityZones) Set the availabilityZones property: The list of Availability zones to use for nodes.Set the count property: Number of agents (VMs) to host docker containers.withCreationData(CreationData creationData) Set the creationData property: CreationData to be used to specify the source Snapshot ID if the node pool will be created/upgraded using a snapshot.withEnableAutoScaling(Boolean enableAutoScaling) Set the enableAutoScaling property: Whether to enable auto-scaler.withEnableEncryptionAtHost(Boolean enableEncryptionAtHost) Set the enableEncryptionAtHost property: Whether to enable host based OS and data drive encryption.withEnableFips(Boolean enableFips) Set the enableFips property: Whether to use a FIPS-enabled OS.withEnableNodePublicIp(Boolean enableNodePublicIp) Set the enableNodePublicIp property: Whether each node is allocated its own public IP.withEnableUltraSsd(Boolean enableUltraSsd) Set the enableUltraSsd property: Whether to enable UltraSSD.withGpuInstanceProfile(GpuInstanceProfile gpuInstanceProfile) Set the gpuInstanceProfile property: GPUInstanceProfile to be used to specify GPU MIG instance profile for supported GPU VM SKU.withHostGroupId(String hostGroupId) Set the hostGroupId property: The fully qualified resource ID of the Dedicated Host Group to provision virtual machines from, used only in creation scenario and not allowed to changed once set.withKubeletConfig(KubeletConfig kubeletConfig) Set the kubeletConfig property: Kubelet configurations of agent nodes.withKubeletDiskType(KubeletDiskType kubeletDiskType) Set the kubeletDiskType property: Determines the placement of emptyDir volumes, container runtime data root, and Kubelet ephemeral storage.withLinuxOSConfig(LinuxOSConfig linuxOSConfig) Set the linuxOSConfig property: OS configurations of Linux agent nodes.withMaxCount(Integer maxCount) Set the maxCount property: The maximum number of nodes for auto-scaling.withMaxPods(Integer maxPods) Set the maxPods property: The maximum number of pods that can run on a node.withMinCount(Integer minCount) Set the minCount property: The minimum number of nodes for auto-scaling.withMode(AgentPoolMode mode) Set the mode property: The mode of an agent pool.Set the name property: Unique name of the agent pool profile in the context of the subscription and resource group.withNodeLabels(Map<String, String> nodeLabels) Set the nodeLabels property: The node labels to be persisted across all nodes in agent pool.withNodePublicIpPrefixId(String nodePublicIpPrefixId) Set the nodePublicIpPrefixId property: The public IP prefix ID which VM nodes should use IPs from.withNodeTaints(List<String> nodeTaints) Set the nodeTaints property: The taints added to new nodes during node pool create and scale.withOrchestratorVersion(String orchestratorVersion) Set the orchestratorVersion property: The version of Kubernetes specified by the user.withOsDiskSizeGB(Integer osDiskSizeGB) Set the osDiskSizeGB property: OS Disk Size in GB to be used to specify the disk size for every machine in the master/agent pool.withOsDiskType(OSDiskType osDiskType) Set the osDiskType property: The OS disk type to be used for machines in the agent pool.Set the osSku property: Specifies the OS SKU used by the agent pool.withOsType(OSType osType) Set the osType property: OsType to be used to specify os type.withPodSubnetId(String podSubnetId) Set the podSubnetId property: The ID of the subnet which pods will join when launched.withPowerState(PowerState powerState) Set the powerState property: When an Agent Pool is first created it is initially Running.withProximityPlacementGroupId(String proximityPlacementGroupId) Set the proximityPlacementGroupId property: The ID for Proximity Placement Group.withScaleDownMode(ScaleDownMode scaleDownMode) Set the scaleDownMode property: This also effects the cluster autoscaler behavior.withScaleSetEvictionPolicy(ScaleSetEvictionPolicy scaleSetEvictionPolicy) Set the scaleSetEvictionPolicy property: The Virtual Machine Scale Set eviction policy.withScaleSetPriority(ScaleSetPriority scaleSetPriority) Set the scaleSetPriority property: The Virtual Machine Scale Set priority.withSpotMaxPrice(Float spotMaxPrice) Set the spotMaxPrice property: The max price (in US Dollars) you are willing to pay for spot instances.Set the tags property: The tags to be persisted on the agent pool virtual machine scale set.withType(AgentPoolType type) Set the type property: The type of Agent Pool.withUpgradeSettings(AgentPoolUpgradeSettings upgradeSettings) Set the upgradeSettings property: Settings for upgrading the agentpool.withVmSize(String vmSize) Set the vmSize property: The size of the agent pool VMs.withVnetSubnetId(String vnetSubnetId) Set the vnetSubnetId property: The ID of the subnet which agent pool nodes and optionally pods will join on startup.withWorkloadRuntime(WorkloadRuntime workloadRuntime) Set the workloadRuntime property: Determines the type of workload a node can run.Methods inherited from class com.azure.resourcemanager.containerservice.fluent.models.ManagedClusterAgentPoolProfileProperties
availabilityZones, count, creationData, currentOrchestratorVersion, enableAutoScaling, enableEncryptionAtHost, enableFips, enableNodePublicIp, enableUltraSsd, gpuInstanceProfile, hostGroupId, kubeletConfig, kubeletDiskType, linuxOSConfig, maxCount, maxPods, minCount, mode, nodeImageVersion, nodeLabels, nodePublicIpPrefixId, nodeTaints, orchestratorVersion, osDiskSizeGB, osDiskType, osSku, osType, podSubnetId, powerState, provisioningState, proximityPlacementGroupId, scaleDownMode, scaleSetEvictionPolicy, scaleSetPriority, spotMaxPrice, tags, type, upgradeSettings, vmSize, vnetSubnetId, workloadRuntime
-
Constructor Details
-
ManagedClusterAgentPoolProfile
public ManagedClusterAgentPoolProfile()
-
-
Method Details
-
name
Get the name property: Unique name of the agent pool profile in the context of the subscription and resource group.Windows agent pool names must be 6 characters or less.
- Returns:
- the name value.
-
withName
Set the name property: Unique name of the agent pool profile in the context of the subscription and resource group.Windows agent pool names must be 6 characters or less.
- Parameters:
name- the name value to set.- Returns:
- the ManagedClusterAgentPoolProfile object itself.
-
withCount
Set the count property: Number of agents (VMs) to host docker containers. Allowed values must be in the range of 0 to 1000 (inclusive) for user pools and in the range of 1 to 1000 (inclusive) for system pools. The default value is 1.- Overrides:
withCountin classManagedClusterAgentPoolProfileProperties- Parameters:
count- the count value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withVmSize
Set the vmSize property: The size of the agent pool VMs.VM size availability varies by region. If a node contains insufficient compute resources (memory, cpu, etc) pods might fail to run correctly. For more details on restricted VM sizes, see: https://docs.microsoft.com/azure/aks/quotas-skus-regions.
- Overrides:
withVmSizein classManagedClusterAgentPoolProfileProperties- Parameters:
vmSize- the vmSize value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withOsDiskSizeGB
Set the osDiskSizeGB property: OS Disk Size in GB to be used to specify the disk size for every machine in the master/agent pool. If you specify 0, it will apply the default osDisk size according to the vmSize specified.- Overrides:
withOsDiskSizeGBin classManagedClusterAgentPoolProfileProperties- Parameters:
osDiskSizeGB- the osDiskSizeGB value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withOsDiskType
Set the osDiskType property: The OS disk type to be used for machines in the agent pool.The default is 'Ephemeral' if the VM supports it and has a cache disk larger than the requested OSDiskSizeGB. Otherwise, defaults to 'Managed'. May not be changed after creation. For more information see [Ephemeral OS](https://docs.microsoft.com/azure/aks/cluster-configuration#ephemeral-os).
- Overrides:
withOsDiskTypein classManagedClusterAgentPoolProfileProperties- Parameters:
osDiskType- the osDiskType value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withKubeletDiskType
Set the kubeletDiskType property: Determines the placement of emptyDir volumes, container runtime data root, and Kubelet ephemeral storage.- Overrides:
withKubeletDiskTypein classManagedClusterAgentPoolProfileProperties- Parameters:
kubeletDiskType- the kubeletDiskType value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withWorkloadRuntime
Set the workloadRuntime property: Determines the type of workload a node can run.- Overrides:
withWorkloadRuntimein classManagedClusterAgentPoolProfileProperties- Parameters:
workloadRuntime- the workloadRuntime value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withVnetSubnetId
Set the vnetSubnetId property: The ID of the subnet which agent pool nodes and optionally pods will join on startup.If this is not specified, a VNET and subnet will be generated and used. If no podSubnetID is specified, this applies to nodes and pods, otherwise it applies to just nodes. This is of the form: /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}/subnets/{subnetName}.
- Overrides:
withVnetSubnetIdin classManagedClusterAgentPoolProfileProperties- Parameters:
vnetSubnetId- the vnetSubnetId value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withPodSubnetId
Set the podSubnetId property: The ID of the subnet which pods will join when launched.If omitted, pod IPs are statically assigned on the node subnet (see vnetSubnetID for more details). This is of the form: /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}/subnets/{subnetName}.
- Overrides:
withPodSubnetIdin classManagedClusterAgentPoolProfileProperties- Parameters:
podSubnetId- the podSubnetId value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withMaxPods
Set the maxPods property: The maximum number of pods that can run on a node.- Overrides:
withMaxPodsin classManagedClusterAgentPoolProfileProperties- Parameters:
maxPods- the maxPods value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withOsType
Set the osType property: OsType to be used to specify os type. Choose from Linux and Windows. Default to Linux.- Overrides:
withOsTypein classManagedClusterAgentPoolProfileProperties- Parameters:
osType- the osType value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withOsSku
Set the osSku property: Specifies the OS SKU used by the agent pool. The default is Ubuntu if OSType is Linux. The default is Windows2019 when Kubernetes <= 1.24 or Windows2022 when Kubernetes >= 1.25 if OSType is Windows.- Overrides:
withOsSkuin classManagedClusterAgentPoolProfileProperties- Parameters:
osSku- the osSku value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withMaxCount
Set the maxCount property: The maximum number of nodes for auto-scaling.- Overrides:
withMaxCountin classManagedClusterAgentPoolProfileProperties- Parameters:
maxCount- the maxCount value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withMinCount
Set the minCount property: The minimum number of nodes for auto-scaling.- Overrides:
withMinCountin classManagedClusterAgentPoolProfileProperties- Parameters:
minCount- the minCount value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withEnableAutoScaling
Set the enableAutoScaling property: Whether to enable auto-scaler.- Overrides:
withEnableAutoScalingin classManagedClusterAgentPoolProfileProperties- Parameters:
enableAutoScaling- the enableAutoScaling value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withScaleDownMode
Set the scaleDownMode property: This also effects the cluster autoscaler behavior. If not specified, it defaults to Delete.- Overrides:
withScaleDownModein classManagedClusterAgentPoolProfileProperties- Parameters:
scaleDownMode- the scaleDownMode value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withType
Set the type property: The type of Agent Pool.- Overrides:
withTypein classManagedClusterAgentPoolProfileProperties- Parameters:
type- the type value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withMode
Set the mode property: The mode of an agent pool.A cluster must have at least one 'System' Agent Pool at all times. For additional information on agent pool restrictions and best practices, see: https://docs.microsoft.com/azure/aks/use-system-pools.
- Overrides:
withModein classManagedClusterAgentPoolProfileProperties- Parameters:
mode- the mode value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withOrchestratorVersion
Set the orchestratorVersion property: The version of Kubernetes specified by the user.Both patch version <major.minor.patch> (e.g. 1.20.13) and <major.minor> (e.g. 1.20) are supported. When <major.minor> is specified, the latest supported GA patch version is chosen automatically. Updating the cluster with the same <major.minor> once it has been created (e.g. 1.14.x -> 1.14) will not trigger an upgrade, even if a newer patch version is available. As a best practice, you should upgrade all node pools in an AKS cluster to the same Kubernetes version. The node pool version must have the same major version as the control plane. The node pool minor version must be within two minor versions of the control plane version. The node pool version cannot be greater than the control plane version. For more information see [upgrading a node pool](https://docs.microsoft.com/azure/aks/use-multiple-node-pools#upgrade-a-node-pool).
- Overrides:
withOrchestratorVersionin classManagedClusterAgentPoolProfileProperties- Parameters:
orchestratorVersion- the orchestratorVersion value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withUpgradeSettings
Set the upgradeSettings property: Settings for upgrading the agentpool.- Overrides:
withUpgradeSettingsin classManagedClusterAgentPoolProfileProperties- Parameters:
upgradeSettings- the upgradeSettings value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withPowerState
Set the powerState property: When an Agent Pool is first created it is initially Running. The Agent Pool can be stopped by setting this field to Stopped. A stopped Agent Pool stops all of its VMs and does not accrue billing charges. An Agent Pool can only be stopped if it is Running and provisioning state is Succeeded.- Overrides:
withPowerStatein classManagedClusterAgentPoolProfileProperties- Parameters:
powerState- the powerState value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withAvailabilityZones
Set the availabilityZones property: The list of Availability zones to use for nodes. This can only be specified if the AgentPoolType property is 'VirtualMachineScaleSets'.- Overrides:
withAvailabilityZonesin classManagedClusterAgentPoolProfileProperties- Parameters:
availabilityZones- the availabilityZones value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withEnableNodePublicIp
Set the enableNodePublicIp property: Whether each node is allocated its own public IP.Some scenarios may require nodes in a node pool to receive their own dedicated public IP addresses. A common scenario is for gaming workloads, where a console needs to make a direct connection to a cloud virtual machine to minimize hops. For more information see [assigning a public IP per node](https://docs.microsoft.com/azure/aks/use-multiple-node-pools#assign-a-public-ip-per-node-for-your-node-pools). The default is false.
- Overrides:
withEnableNodePublicIpin classManagedClusterAgentPoolProfileProperties- Parameters:
enableNodePublicIp- the enableNodePublicIp value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withNodePublicIpPrefixId
Set the nodePublicIpPrefixId property: The public IP prefix ID which VM nodes should use IPs from.This is of the form: /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/publicIPPrefixes/{publicIPPrefixName}.
- Overrides:
withNodePublicIpPrefixIdin classManagedClusterAgentPoolProfileProperties- Parameters:
nodePublicIpPrefixId- the nodePublicIpPrefixId value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withScaleSetPriority
Set the scaleSetPriority property: The Virtual Machine Scale Set priority. If not specified, the default is 'Regular'.- Overrides:
withScaleSetPriorityin classManagedClusterAgentPoolProfileProperties- Parameters:
scaleSetPriority- the scaleSetPriority value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withScaleSetEvictionPolicy
public ManagedClusterAgentPoolProfile withScaleSetEvictionPolicy(ScaleSetEvictionPolicy scaleSetEvictionPolicy) Set the scaleSetEvictionPolicy property: The Virtual Machine Scale Set eviction policy.This cannot be specified unless the scaleSetPriority is 'Spot'. If not specified, the default is 'Delete'.
- Overrides:
withScaleSetEvictionPolicyin classManagedClusterAgentPoolProfileProperties- Parameters:
scaleSetEvictionPolicy- the scaleSetEvictionPolicy value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withSpotMaxPrice
Set the spotMaxPrice property: The max price (in US Dollars) you are willing to pay for spot instances. Possible values are any decimal value greater than zero or -1 which indicates default price to be up-to on-demand.Possible values are any decimal value greater than zero or -1 which indicates the willingness to pay any on-demand price. For more details on spot pricing, see [spot VMs pricing](https://docs.microsoft.com/azure/virtual-machines/spot-vms#pricing).
- Overrides:
withSpotMaxPricein classManagedClusterAgentPoolProfileProperties- Parameters:
spotMaxPrice- the spotMaxPrice value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withTags
Set the tags property: The tags to be persisted on the agent pool virtual machine scale set.- Overrides:
withTagsin classManagedClusterAgentPoolProfileProperties- Parameters:
tags- the tags value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withNodeLabels
Set the nodeLabels property: The node labels to be persisted across all nodes in agent pool.- Overrides:
withNodeLabelsin classManagedClusterAgentPoolProfileProperties- Parameters:
nodeLabels- the nodeLabels value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withNodeTaints
Set the nodeTaints property: The taints added to new nodes during node pool create and scale. For example, key=value:NoSchedule.- Overrides:
withNodeTaintsin classManagedClusterAgentPoolProfileProperties- Parameters:
nodeTaints- the nodeTaints value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withProximityPlacementGroupId
public ManagedClusterAgentPoolProfile withProximityPlacementGroupId(String proximityPlacementGroupId) Set the proximityPlacementGroupId property: The ID for Proximity Placement Group.- Overrides:
withProximityPlacementGroupIdin classManagedClusterAgentPoolProfileProperties- Parameters:
proximityPlacementGroupId- the proximityPlacementGroupId value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withKubeletConfig
Set the kubeletConfig property: Kubelet configurations of agent nodes.The Kubelet configuration on the agent pool nodes.
- Overrides:
withKubeletConfigin classManagedClusterAgentPoolProfileProperties- Parameters:
kubeletConfig- the kubeletConfig value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withLinuxOSConfig
Set the linuxOSConfig property: OS configurations of Linux agent nodes.The OS configuration of Linux agent nodes.
- Overrides:
withLinuxOSConfigin classManagedClusterAgentPoolProfileProperties- Parameters:
linuxOSConfig- the linuxOSConfig value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withEnableEncryptionAtHost
Set the enableEncryptionAtHost property: Whether to enable host based OS and data drive encryption.This is only supported on certain VM sizes and in certain Azure regions. For more information, see: https://docs.microsoft.com/azure/aks/enable-host-encryption.
- Overrides:
withEnableEncryptionAtHostin classManagedClusterAgentPoolProfileProperties- Parameters:
enableEncryptionAtHost- the enableEncryptionAtHost value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withEnableUltraSsd
Set the enableUltraSsd property: Whether to enable UltraSSD.- Overrides:
withEnableUltraSsdin classManagedClusterAgentPoolProfileProperties- Parameters:
enableUltraSsd- the enableUltraSsd value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withEnableFips
Set the enableFips property: Whether to use a FIPS-enabled OS.See [Add a FIPS-enabled node pool](https://docs.microsoft.com/azure/aks/use-multiple-node-pools#add-a-fips-enabled-node-pool-preview) for more details.
- Overrides:
withEnableFipsin classManagedClusterAgentPoolProfileProperties- Parameters:
enableFips- the enableFips value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withGpuInstanceProfile
Set the gpuInstanceProfile property: GPUInstanceProfile to be used to specify GPU MIG instance profile for supported GPU VM SKU.- Overrides:
withGpuInstanceProfilein classManagedClusterAgentPoolProfileProperties- Parameters:
gpuInstanceProfile- the gpuInstanceProfile value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withCreationData
Set the creationData property: CreationData to be used to specify the source Snapshot ID if the node pool will be created/upgraded using a snapshot.- Overrides:
withCreationDatain classManagedClusterAgentPoolProfileProperties- Parameters:
creationData- the creationData value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
withHostGroupId
Set the hostGroupId property: The fully qualified resource ID of the Dedicated Host Group to provision virtual machines from, used only in creation scenario and not allowed to changed once set.This is of the form: /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Compute/hostGroups/{hostGroupName}. For more information see [Azure dedicated hosts](https://docs.microsoft.com/azure/virtual-machines/dedicated-hosts).
- Overrides:
withHostGroupIdin classManagedClusterAgentPoolProfileProperties- Parameters:
hostGroupId- the hostGroupId value to set.- Returns:
- the ManagedClusterAgentPoolProfileProperties object itself.
-
validate
public void validate()Validates the instance.- Overrides:
validatein classManagedClusterAgentPoolProfileProperties- Throws:
IllegalArgumentException- thrown if the instance is not valid.
-