Package com.azure.compute.batch.models
Class BatchPoolCreateContent
java.lang.Object
com.azure.compute.batch.models.BatchPoolCreateContent
- All Implemented Interfaces:
com.azure.json.JsonSerializable<BatchPoolCreateContent>
public final class BatchPoolCreateContent
extends Object
implements com.azure.json.JsonSerializable<BatchPoolCreateContent>
Parameters for creating an Azure Batch Pool.
-
Constructor Summary
ConstructorsConstructorDescriptionBatchPoolCreateContent
(String id, String vmSize) Creates an instance of BatchPoolCreateContent class. -
Method Summary
Modifier and TypeMethodDescriptionstatic BatchPoolCreateContent
fromJson
(com.azure.json.JsonReader jsonReader) Reads an instance of BatchPoolCreateContent from the JsonReader.Get the applicationPackageReferences property: The list of Packages to be installed on each Compute Node in the Pool.Get the autoScaleEvaluationInterval property: The time interval at which to automatically adjust the Pool size according to the autoscale formula.Get the autoScaleFormula property: A formula for the desired number of Compute Nodes in the Pool.Get the certificateReferences property: For Windows Nodes, the Batch service installs the Certificates to the specified Certificate store and location.Get the displayName property: The display name for the Pool.getId()
Get the id property: A string that uniquely identifies the Pool within the Account.Get the metadata property: A list of name-value pairs associated with the Pool as metadata.Get the mountConfiguration property: Mount storage using specified file system for the entire lifetime of the pool.Get the networkConfiguration property: The network configuration for the Pool.Get the resizeTimeout property: The timeout for allocation of Compute Nodes to the Pool.Get the resourceTags property: The user-specified tags associated with the pool.Get the startTask property: A Task specified to run on each Compute Node as it joins the Pool.Get the targetDedicatedNodes property: The desired number of dedicated Compute Nodes in the Pool.Get the targetLowPriorityNodes property: The desired number of Spot/Low-priority Compute Nodes in the Pool.Get the targetNodeCommunicationMode property: The desired node communication mode for the pool.Get the taskSchedulingPolicy property: How Tasks are distributed across Compute Nodes in a Pool.Get the taskSlotsPerNode property: The number of task slots that can be used to run concurrent tasks on a single compute node in the pool.Get the upgradePolicy property: The upgrade policy for the Pool.Get the userAccounts property: The list of user Accounts to be created on each Compute Node in the Pool.Get the virtualMachineConfiguration property: The virtual machine configuration for the Pool.Get the vmSize property: The size of virtual machines in the Pool.Get the enableAutoScale property: Whether the Pool size should automatically adjust over time.Get the enableInterNodeCommunication property: Whether the Pool permits direct communication between Compute Nodes.setApplicationPackageReferences
(List<BatchApplicationPackageReference> applicationPackageReferences) Set the applicationPackageReferences property: The list of Packages to be installed on each Compute Node in the Pool.setAutoScaleEvaluationInterval
(Duration autoScaleEvaluationInterval) Set the autoScaleEvaluationInterval property: The time interval at which to automatically adjust the Pool size according to the autoscale formula.setAutoScaleFormula
(String autoScaleFormula) Set the autoScaleFormula property: A formula for the desired number of Compute Nodes in the Pool.setCertificateReferences
(List<BatchCertificateReference> certificateReferences) Set the certificateReferences property: For Windows Nodes, the Batch service installs the Certificates to the specified Certificate store and location.setDisplayName
(String displayName) Set the displayName property: The display name for the Pool.setEnableAutoScale
(Boolean enableAutoScale) Set the enableAutoScale property: Whether the Pool size should automatically adjust over time.setEnableInterNodeCommunication
(Boolean enableInterNodeCommunication) Set the enableInterNodeCommunication property: Whether the Pool permits direct communication between Compute Nodes.setMetadata
(List<MetadataItem> metadata) Set the metadata property: A list of name-value pairs associated with the Pool as metadata.setMountConfiguration
(List<MountConfiguration> mountConfiguration) Set the mountConfiguration property: Mount storage using specified file system for the entire lifetime of the pool.setNetworkConfiguration
(NetworkConfiguration networkConfiguration) Set the networkConfiguration property: The network configuration for the Pool.setResizeTimeout
(Duration resizeTimeout) Set the resizeTimeout property: The timeout for allocation of Compute Nodes to the Pool.setResourceTags
(Map<String, String> resourceTags) Set the resourceTags property: The user-specified tags associated with the pool.setStartTask
(BatchStartTask startTask) Set the startTask property: A Task specified to run on each Compute Node as it joins the Pool.setTargetDedicatedNodes
(Integer targetDedicatedNodes) Set the targetDedicatedNodes property: The desired number of dedicated Compute Nodes in the Pool.setTargetLowPriorityNodes
(Integer targetLowPriorityNodes) Set the targetLowPriorityNodes property: The desired number of Spot/Low-priority Compute Nodes in the Pool.setTargetNodeCommunicationMode
(BatchNodeCommunicationMode targetNodeCommunicationMode) Set the targetNodeCommunicationMode property: The desired node communication mode for the pool.setTaskSchedulingPolicy
(BatchTaskSchedulingPolicy taskSchedulingPolicy) Set the taskSchedulingPolicy property: How Tasks are distributed across Compute Nodes in a Pool.setTaskSlotsPerNode
(Integer taskSlotsPerNode) Set the taskSlotsPerNode property: The number of task slots that can be used to run concurrent tasks on a single compute node in the pool.setUpgradePolicy
(UpgradePolicy upgradePolicy) Set the upgradePolicy property: The upgrade policy for the Pool.setUserAccounts
(List<UserAccount> userAccounts) Set the userAccounts property: The list of user Accounts to be created on each Compute Node in the Pool.setVirtualMachineConfiguration
(VirtualMachineConfiguration virtualMachineConfiguration) Set the virtualMachineConfiguration property: The virtual machine configuration for the Pool.com.azure.json.JsonWriter
toJson
(com.azure.json.JsonWriter jsonWriter) Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface com.azure.json.JsonSerializable
toJson, toJson, toJsonBytes, toJsonString
-
Constructor Details
-
BatchPoolCreateContent
Creates an instance of BatchPoolCreateContent class.- Parameters:
id
- the id value to set.vmSize
- the vmSize value to set.
-
-
Method Details
-
getId
Get the id property: A string that uniquely identifies the Pool within the Account. The ID can contain any combination of alphanumeric characters including hyphens and underscores, and cannot contain more than 64 characters. The ID is case-preserving and case-insensitive (that is, you may not have two Pool IDs within an Account that differ only by case).- Returns:
- the id value.
-
getDisplayName
Get the displayName property: The display name for the Pool. The display name need not be unique and can contain any Unicode characters up to a maximum length of 1024.- Returns:
- the displayName value.
-
setDisplayName
Set the displayName property: The display name for the Pool. The display name need not be unique and can contain any Unicode characters up to a maximum length of 1024.- Parameters:
displayName
- the displayName value to set.- Returns:
- the BatchPoolCreateContent object itself.
-
getVmSize
Get the vmSize property: The size of virtual machines in the Pool. All virtual machines in a Pool are the same size. For information about available VM sizes for Pools using Images from the Virtual Machines Marketplace (pools created with virtualMachineConfiguration), see Sizes for Virtual Machines in Azure (https://learn.microsoft.com/azure/virtual-machines/sizes/overview). Batch supports all Azure VM sizes except STANDARD_A0 and those with premium storage (STANDARD_GS, STANDARD_DS, and STANDARD_DSV2 series).- Returns:
- the vmSize value.
-
getVirtualMachineConfiguration
Get the virtualMachineConfiguration property: The virtual machine configuration for the Pool. This property must be specified.- Returns:
- the virtualMachineConfiguration value.
-
setVirtualMachineConfiguration
public BatchPoolCreateContent setVirtualMachineConfiguration(VirtualMachineConfiguration virtualMachineConfiguration) Set the virtualMachineConfiguration property: The virtual machine configuration for the Pool. This property must be specified.- Parameters:
virtualMachineConfiguration
- the virtualMachineConfiguration value to set.- Returns:
- the BatchPoolCreateContent object itself.
-
getResizeTimeout
Get the resizeTimeout property: The timeout for allocation of Compute Nodes to the Pool. This timeout applies only to manual scaling; it has no effect when enableAutoScale is set to true. The default value is 15 minutes. The minimum value is 5 minutes. If you specify a value less than 5 minutes, the Batch service returns an error; if you are calling the REST API directly, the HTTP status code is 400 (Bad Request).- Returns:
- the resizeTimeout value.
-
setResizeTimeout
Set the resizeTimeout property: The timeout for allocation of Compute Nodes to the Pool. This timeout applies only to manual scaling; it has no effect when enableAutoScale is set to true. The default value is 15 minutes. The minimum value is 5 minutes. If you specify a value less than 5 minutes, the Batch service returns an error; if you are calling the REST API directly, the HTTP status code is 400 (Bad Request).- Parameters:
resizeTimeout
- the resizeTimeout value to set.- Returns:
- the BatchPoolCreateContent object itself.
-
getResourceTags
Get the resourceTags property: The user-specified tags associated with the pool. The user-defined tags to be associated with the Azure Batch Pool. When specified, these tags are propagated to the backing Azure resources associated with the pool. This property can only be specified when the Batch account was created with the poolAllocationMode property set to 'UserSubscription'.- Returns:
- the resourceTags value.
-
setResourceTags
Set the resourceTags property: The user-specified tags associated with the pool. The user-defined tags to be associated with the Azure Batch Pool. When specified, these tags are propagated to the backing Azure resources associated with the pool. This property can only be specified when the Batch account was created with the poolAllocationMode property set to 'UserSubscription'.- Parameters:
resourceTags
- the resourceTags value to set.- Returns:
- the BatchPoolCreateContent object itself.
-
getTargetDedicatedNodes
Get the targetDedicatedNodes property: The desired number of dedicated Compute Nodes in the Pool. This property must not be specified if enableAutoScale is set to true. If enableAutoScale is set to false, then you must set either targetDedicatedNodes, targetLowPriorityNodes, or both.- Returns:
- the targetDedicatedNodes value.
-
setTargetDedicatedNodes
Set the targetDedicatedNodes property: The desired number of dedicated Compute Nodes in the Pool. This property must not be specified if enableAutoScale is set to true. If enableAutoScale is set to false, then you must set either targetDedicatedNodes, targetLowPriorityNodes, or both.- Parameters:
targetDedicatedNodes
- the targetDedicatedNodes value to set.- Returns:
- the BatchPoolCreateContent object itself.
-
getTargetLowPriorityNodes
Get the targetLowPriorityNodes property: The desired number of Spot/Low-priority Compute Nodes in the Pool. This property must not be specified if enableAutoScale is set to true. If enableAutoScale is set to false, then you must set either targetDedicatedNodes, targetLowPriorityNodes, or both.- Returns:
- the targetLowPriorityNodes value.
-
setTargetLowPriorityNodes
Set the targetLowPriorityNodes property: The desired number of Spot/Low-priority Compute Nodes in the Pool. This property must not be specified if enableAutoScale is set to true. If enableAutoScale is set to false, then you must set either targetDedicatedNodes, targetLowPriorityNodes, or both.- Parameters:
targetLowPriorityNodes
- the targetLowPriorityNodes value to set.- Returns:
- the BatchPoolCreateContent object itself.
-
isEnableAutoScale
Get the enableAutoScale property: Whether the Pool size should automatically adjust over time. If false, at least one of targetDedicatedNodes and targetLowPriorityNodes must be specified. If true, the autoScaleFormula property is required and the Pool automatically resizes according to the formula. The default value is false.- Returns:
- the enableAutoScale value.
-
setEnableAutoScale
Set the enableAutoScale property: Whether the Pool size should automatically adjust over time. If false, at least one of targetDedicatedNodes and targetLowPriorityNodes must be specified. If true, the autoScaleFormula property is required and the Pool automatically resizes according to the formula. The default value is false.- Parameters:
enableAutoScale
- the enableAutoScale value to set.- Returns:
- the BatchPoolCreateContent object itself.
-
getAutoScaleFormula
Get the autoScaleFormula property: A formula for the desired number of Compute Nodes in the Pool. This property must not be specified if enableAutoScale is set to false. It is required if enableAutoScale is set to true. The formula is checked for validity before the Pool is created. If the formula is not valid, the Batch service rejects the request with detailed error information. For more information about specifying this formula, see 'Automatically scale Compute Nodes in an Azure Batch Pool' (https://learn.microsoft.com/azure/batch/batch-automatic-scaling).- Returns:
- the autoScaleFormula value.
-
setAutoScaleFormula
Set the autoScaleFormula property: A formula for the desired number of Compute Nodes in the Pool. This property must not be specified if enableAutoScale is set to false. It is required if enableAutoScale is set to true. The formula is checked for validity before the Pool is created. If the formula is not valid, the Batch service rejects the request with detailed error information. For more information about specifying this formula, see 'Automatically scale Compute Nodes in an Azure Batch Pool' (https://learn.microsoft.com/azure/batch/batch-automatic-scaling).- Parameters:
autoScaleFormula
- the autoScaleFormula value to set.- Returns:
- the BatchPoolCreateContent object itself.
-
getAutoScaleEvaluationInterval
Get the autoScaleEvaluationInterval property: The time interval at which to automatically adjust the Pool size according to the autoscale formula. The default value is 15 minutes. The minimum and maximum value are 5 minutes and 168 hours respectively. If you specify a value less than 5 minutes or greater than 168 hours, the Batch service returns an error; if you are calling the REST API directly, the HTTP status code is 400 (Bad Request).- Returns:
- the autoScaleEvaluationInterval value.
-
setAutoScaleEvaluationInterval
Set the autoScaleEvaluationInterval property: The time interval at which to automatically adjust the Pool size according to the autoscale formula. The default value is 15 minutes. The minimum and maximum value are 5 minutes and 168 hours respectively. If you specify a value less than 5 minutes or greater than 168 hours, the Batch service returns an error; if you are calling the REST API directly, the HTTP status code is 400 (Bad Request).- Parameters:
autoScaleEvaluationInterval
- the autoScaleEvaluationInterval value to set.- Returns:
- the BatchPoolCreateContent object itself.
-
isEnableInterNodeCommunication
Get the enableInterNodeCommunication property: Whether the Pool permits direct communication between Compute Nodes. Enabling inter-node communication limits the maximum size of the Pool due to deployment restrictions on the Compute Nodes of the Pool. This may result in the Pool not reaching its desired size. The default value is false.- Returns:
- the enableInterNodeCommunication value.
-
setEnableInterNodeCommunication
Set the enableInterNodeCommunication property: Whether the Pool permits direct communication between Compute Nodes. Enabling inter-node communication limits the maximum size of the Pool due to deployment restrictions on the Compute Nodes of the Pool. This may result in the Pool not reaching its desired size. The default value is false.- Parameters:
enableInterNodeCommunication
- the enableInterNodeCommunication value to set.- Returns:
- the BatchPoolCreateContent object itself.
-
getNetworkConfiguration
Get the networkConfiguration property: The network configuration for the Pool.- Returns:
- the networkConfiguration value.
-
setNetworkConfiguration
Set the networkConfiguration property: The network configuration for the Pool.- Parameters:
networkConfiguration
- the networkConfiguration value to set.- Returns:
- the BatchPoolCreateContent object itself.
-
getStartTask
Get the startTask property: A Task specified to run on each Compute Node as it joins the Pool. The Task runs when the Compute Node is added to the Pool or when the Compute Node is restarted.- Returns:
- the startTask value.
-
setStartTask
Set the startTask property: A Task specified to run on each Compute Node as it joins the Pool. The Task runs when the Compute Node is added to the Pool or when the Compute Node is restarted.- Parameters:
startTask
- the startTask value to set.- Returns:
- the BatchPoolCreateContent object itself.
-
getCertificateReferences
Get the certificateReferences property: For Windows Nodes, the Batch service installs the Certificates to the specified Certificate store and location. For Linux Compute Nodes, the Certificates are stored in a directory inside the Task working directory and an environment variable AZ_BATCH_CERTIFICATES_DIR is supplied to the Task to query for this location. For Certificates with visibility of 'remoteUser', a 'certs' directory is created in the user's home directory (e.g., /home/{user-name}/certs) and Certificates are placed in that directory. Warning: This property is deprecated and will be removed after February, 2024. Please use the [Azure KeyVault Extension](https://learn.microsoft.com/azure/batch/batch-certificate-migration-guide) instead.- Returns:
- the certificateReferences value.
-
setCertificateReferences
public BatchPoolCreateContent setCertificateReferences(List<BatchCertificateReference> certificateReferences) Set the certificateReferences property: For Windows Nodes, the Batch service installs the Certificates to the specified Certificate store and location. For Linux Compute Nodes, the Certificates are stored in a directory inside the Task working directory and an environment variable AZ_BATCH_CERTIFICATES_DIR is supplied to the Task to query for this location. For Certificates with visibility of 'remoteUser', a 'certs' directory is created in the user's home directory (e.g., /home/{user-name}/certs) and Certificates are placed in that directory. Warning: This property is deprecated and will be removed after February, 2024. Please use the [Azure KeyVault Extension](https://learn.microsoft.com/azure/batch/batch-certificate-migration-guide) instead.- Parameters:
certificateReferences
- the certificateReferences value to set.- Returns:
- the BatchPoolCreateContent object itself.
-
getApplicationPackageReferences
Get the applicationPackageReferences property: The list of Packages to be installed on each Compute Node in the Pool. When creating a pool, the package's application ID must be fully qualified (/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Batch/batchAccounts/{accountName}/applications/{applicationName}). Changes to Package references affect all new Nodes joining the Pool, but do not affect Compute Nodes that are already in the Pool until they are rebooted or reimaged. There is a maximum of 10 Package references on any given Pool.- Returns:
- the applicationPackageReferences value.
-
setApplicationPackageReferences
public BatchPoolCreateContent setApplicationPackageReferences(List<BatchApplicationPackageReference> applicationPackageReferences) Set the applicationPackageReferences property: The list of Packages to be installed on each Compute Node in the Pool. When creating a pool, the package's application ID must be fully qualified (/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Batch/batchAccounts/{accountName}/applications/{applicationName}). Changes to Package references affect all new Nodes joining the Pool, but do not affect Compute Nodes that are already in the Pool until they are rebooted or reimaged. There is a maximum of 10 Package references on any given Pool.- Parameters:
applicationPackageReferences
- the applicationPackageReferences value to set.- Returns:
- the BatchPoolCreateContent object itself.
-
getTaskSlotsPerNode
Get the taskSlotsPerNode property: The number of task slots that can be used to run concurrent tasks on a single compute node in the pool. The default value is 1. The maximum value is the smaller of 4 times the number of cores of the vmSize of the pool or 256.- Returns:
- the taskSlotsPerNode value.
-
setTaskSlotsPerNode
Set the taskSlotsPerNode property: The number of task slots that can be used to run concurrent tasks on a single compute node in the pool. The default value is 1. The maximum value is the smaller of 4 times the number of cores of the vmSize of the pool or 256.- Parameters:
taskSlotsPerNode
- the taskSlotsPerNode value to set.- Returns:
- the BatchPoolCreateContent object itself.
-
getTaskSchedulingPolicy
Get the taskSchedulingPolicy property: How Tasks are distributed across Compute Nodes in a Pool. If not specified, the default is spread.- Returns:
- the taskSchedulingPolicy value.
-
setTaskSchedulingPolicy
public BatchPoolCreateContent setTaskSchedulingPolicy(BatchTaskSchedulingPolicy taskSchedulingPolicy) Set the taskSchedulingPolicy property: How Tasks are distributed across Compute Nodes in a Pool. If not specified, the default is spread.- Parameters:
taskSchedulingPolicy
- the taskSchedulingPolicy value to set.- Returns:
- the BatchPoolCreateContent object itself.
-
getUserAccounts
Get the userAccounts property: The list of user Accounts to be created on each Compute Node in the Pool.- Returns:
- the userAccounts value.
-
setUserAccounts
Set the userAccounts property: The list of user Accounts to be created on each Compute Node in the Pool.- Parameters:
userAccounts
- the userAccounts value to set.- Returns:
- the BatchPoolCreateContent object itself.
-
getMetadata
Get the metadata property: A list of name-value pairs associated with the Pool as metadata. The Batch service does not assign any meaning to metadata; it is solely for the use of user code.- Returns:
- the metadata value.
-
setMetadata
Set the metadata property: A list of name-value pairs associated with the Pool as metadata. The Batch service does not assign any meaning to metadata; it is solely for the use of user code.- Parameters:
metadata
- the metadata value to set.- Returns:
- the BatchPoolCreateContent object itself.
-
getMountConfiguration
Get the mountConfiguration property: Mount storage using specified file system for the entire lifetime of the pool. Mount the storage using Azure fileshare, NFS, CIFS or Blobfuse based file system.- Returns:
- the mountConfiguration value.
-
setMountConfiguration
Set the mountConfiguration property: Mount storage using specified file system for the entire lifetime of the pool. Mount the storage using Azure fileshare, NFS, CIFS or Blobfuse based file system.- Parameters:
mountConfiguration
- the mountConfiguration value to set.- Returns:
- the BatchPoolCreateContent object itself.
-
getTargetNodeCommunicationMode
Get the targetNodeCommunicationMode property: The desired node communication mode for the pool. If omitted, the default value is Default.- Returns:
- the targetNodeCommunicationMode value.
-
setTargetNodeCommunicationMode
public BatchPoolCreateContent setTargetNodeCommunicationMode(BatchNodeCommunicationMode targetNodeCommunicationMode) Set the targetNodeCommunicationMode property: The desired node communication mode for the pool. If omitted, the default value is Default.- Parameters:
targetNodeCommunicationMode
- the targetNodeCommunicationMode value to set.- Returns:
- the BatchPoolCreateContent object itself.
-
getUpgradePolicy
Get the upgradePolicy property: The upgrade policy for the Pool. Describes an upgrade policy - automatic, manual, or rolling.- Returns:
- the upgradePolicy value.
-
setUpgradePolicy
Set the upgradePolicy property: The upgrade policy for the Pool. Describes an upgrade policy - automatic, manual, or rolling.- Parameters:
upgradePolicy
- the upgradePolicy value to set.- Returns:
- the BatchPoolCreateContent object itself.
-
toJson
- Specified by:
toJson
in interfacecom.azure.json.JsonSerializable<BatchPoolCreateContent>
- Throws:
IOException
-
fromJson
public static BatchPoolCreateContent fromJson(com.azure.json.JsonReader jsonReader) throws IOException Reads an instance of BatchPoolCreateContent from the JsonReader.- Parameters:
jsonReader
- The JsonReader being read.- Returns:
- An instance of BatchPoolCreateContent if the JsonReader was pointing to an instance of it, or null if it was pointing to JSON null.
- Throws:
IllegalStateException
- If the deserialized JSON object was missing any required properties.IOException
- If an error occurs while reading the BatchPoolCreateContent.
-