Pool - Add
Adds a Pool to the specified Account.
When naming Pools, avoid including sensitive information such as user names or secret project names. This information may appear in telemetry logs accessible to Microsoft Support engineers.
POST {batchUrl}/pools?api-version=2024-07-01.20.0POST {batchUrl}/pools?timeout={timeout}&api-version=2024-07-01.20.0URI Parameters
| Name | In | Required | Type | Description | 
|---|---|---|---|---|
| batch | path | True | string | The base URL for all Azure Batch service requests. | 
| api-version | query | True | string | Client API Version. | 
| timeout | query | integer (int32) | The maximum time that the server can spend processing the request, in seconds. The default is 30 seconds. If the value is larger than 30, the default will be used instead. | 
Request Header
Media Types: "application/json; odata=minimalmetadata"
| Name | Required | Type | Description | 
|---|---|---|---|
| client-request-id | string (uuid) | The caller-generated request identity, in the form of a GUID with no decoration such as curly braces, e.g. 9C4D50EE-2D56-4CD3-8152-34347DC9F2B0. | |
| return-client-request-id | boolean | Whether the server should return the client-request-id in the response. | |
| ocp-date | string (date-time-rfc1123) | The time the request was issued. Client libraries typically set this to the current system clock time; set it explicitly if you are calling the REST API directly. | 
Request Body
Media Types: "application/json; odata=minimalmetadata"
| Name | Required | Type | Description | 
|---|---|---|---|
| id | True | string | A string that uniquely identifies the Pool within the Account. | 
| vmSize | True | string | The size of virtual machines in the Pool. All virtual machines in a Pool are the same size. | 
| applicationPackageReferences | The list of Packages to be installed on each Compute Node in the Pool. | ||
| autoScaleEvaluationInterval | string (duration) | The time interval at which to automatically adjust the Pool size according to the autoscale formula. | |
| autoScaleFormula | string | A formula for the desired number of Compute Nodes in the Pool. | |
| certificateReferences | The list of Certificates to be installed on each Compute Node in the Pool. Warning: This property is deprecated and will be removed after February, 2024. Please use the Azure KeyVault Extension instead. | ||
| displayName | string | The display name for the Pool. | |
| enableAutoScale | boolean | Whether the Pool size should automatically adjust over time. | |
| enableInterNodeCommunication | boolean | Whether the Pool permits direct communication between Compute Nodes. | |
| metadata | A list of name-value pairs associated with the Pool as metadata. | ||
| mountConfiguration | Mount storage using specified file system for the entire lifetime of the pool. | ||
| networkConfiguration | The network configuration for the Pool. | ||
| resizeTimeout | string (duration) | The timeout for allocation of Compute Nodes to the Pool. | |
| resourceTags | object | The user-specified tags associated with the pool. | |
| startTask | A Task specified to run on each Compute Node as it joins the Pool. | ||
| targetDedicatedNodes | integer (int32) | The desired number of dedicated Compute Nodes in the Pool. | |
| targetLowPriorityNodes | integer (int32) | The desired number of Spot/Low-priority Compute Nodes in the Pool. | |
| targetNodeCommunicationMode | The desired node communication mode for the pool. | ||
| taskSchedulingPolicy | How Tasks are distributed across Compute Nodes in a Pool. | ||
| taskSlotsPerNode | integer (int32) | The number of task slots that can be used to run concurrent tasks on a single compute node in the pool. | |
| upgradePolicy | The upgrade policy for the Pool. | ||
| userAccounts | The list of user Accounts to be created on each Compute Node in the Pool. | ||
| virtualMachineConfiguration | The virtual machine configuration for the Pool. | 
Responses
| Name | Type | Description | 
|---|---|---|
| 201 Created | The request to the Batch service was successful. Headers 
 | |
| Other Status Codes | The error from the Batch service. | 
Security
azure_auth
Microsoft Entra OAuth 2.0 auth code flow
					Type: 
					oauth2
					Flow: 
					implicit
					Authorization URL: 
					https://login.microsoftonline.com/common/oauth2/authorize
			
Scopes
| Name | Description | 
|---|---|
| user_impersonation | Impersonate your user account | 
Authorization
					Type: 
					apiKey
					In: 
					header
			
Examples
Add a pool with accelerated networking
Sample request
POST account.region.batch.azure.com/pools?api-version=2024-07-01.20.0
{
  "id": "mypool01",
  "vmSize": "Standard_D1_v2",
  "virtualMachineConfiguration": {
    "imageReference": {
      "publisher": "MicrosoftWindowsServer",
      "offer": "WindowsServer",
      "sku": "2016-datacenter-smalldisk",
      "version": "latest"
    },
    "nodeAgentSKUId": "batch.node.windows amd64"
  },
  "targetDedicatedNodes": 2,
  "networkConfiguration": {
    "enableAcceleratedNetworking": true
  }
}
Sample response
Add a pool with mount drive specified
Sample request
POST account.region.batch.azure.com/pools?api-version=2024-07-01.20.0
{
  "id": "pool2",
  "vmSize": "standard_a1",
  "virtualMachineConfiguration": {
    "imageReference": {
      "publisher": "Canonical",
      "offer": "UbuntuServer",
      "sku": "20_04-lts"
    },
    "nodeAgentSKUId": "batch.node.ubuntu 20.04"
  },
  "mountConfiguration": [
    {
      "azureBlobFileSystemConfiguration": {
        "accountName": "accountName",
        "containerName": "blobContainerName",
        "accountKey": "accountKey",
        "relativeMountPath": "bfusepath"
      }
    },
    {
      "azureFileShareConfiguration": {
        "accountName": "accountName",
        "azureFileUrl": "https://myaccount.file.core.windows.net/fileshare",
        "accountKey": "accountKey",
        "relativeMountPath": "filesharepath",
        "mountOptions": "mount options ver=1.0"
      }
    },
    {
      "nfsMountConfiguration": {
        "source": "somesource nfs url",
        "relativeMountPath": "mountpath",
        "mountOptions": "mount options ver=1.0"
      }
    },
    {
      "cifsMountConfiguration": {
        "username": "accountName",
        "password": "password",
        "source": "//myaccount.file.core.windows.net/file",
        "relativeMountPath": "mountpath",
        "mountOptions": "mount options ver=1.0"
      }
    }
  ],
  "resizeTimeout": "PT15M",
  "targetDedicatedNodes": 5,
  "targetLowPriorityNodes": 0,
  "taskSlotsPerNode": 3,
  "taskSchedulingPolicy": {
    "nodeFillType": "spread"
  },
  "enableAutoScale": false
}
Sample response
Add a pool with SecurityProfile 
			Sample request
POST account.region.batch.azure.com/pools?api-version=2024-07-01.20.0
{
  "id": "mypool001",
  "vmSize": "STANDARD_DC2s_V2",
  "virtualMachineConfiguration": {
    "imageReference": {
      "publisher": "Canonical",
      "offer": "UbuntuServer",
      "sku": "18_04-lts-gen2",
      "version": "latest"
    },
    "nodeAgentSKUId": "batch.node.ubuntu 18.04",
    "securityProfile": {
      "securityType": "trustedLaunch",
      "encryptionAtHost": true,
      "uefiSettings": {
        "secureBootEnabled": false,
        "vTpmEnabled": null
      }
    }
  },
  "targetDedicatedNodes": 1
}
Sample response
Add a pool with UpgradePolicy 
			Sample request
POST account.region.batch.azure.com/pools?api-version=2024-07-01.20.0
{
  "id": "mypool001",
  "vmSize": "Standard_A1_v2",
  "virtualMachineConfiguration": {
    "imageReference": {
      "publisher": "MicrosoftWindowsServer",
      "offer": "WindowsServer",
      "sku": "2016-datacenter-smalldisk",
      "version": "latest"
    },
    "windowsConfiguration": {
      "enableAutomaticUpdates": false
    },
    "nodePlacementConfiguration": {
      "policy": "zonal"
    },
    "nodeAgentSKUId": "batch.node.windows amd64"
  },
  "targetDedicatedNodes": 2,
  "upgradePolicy": {
    "mode": "automatic",
    "automaticOSUpgradePolicy": {
      "disableAutomaticRollback": true,
      "enableAutomaticOSUpgrade": true,
      "useRollingUpgradePolicy": true,
      "osRollingUpgradeDeferral": true
    },
    "rollingUpgradePolicy": {
      "enableCrossZoneUpgrade": true,
      "maxBatchInstancePercent": 20,
      "maxUnhealthyInstancePercent": 20,
      "maxUnhealthyUpgradedInstancePercent": 20,
      "pauseTimeBetweenBatches": "PT0S",
      "prioritizeUnhealthyInstances": false,
      "rollbackFailedInstancesOnPolicyBreach": false
    }
  }
}
Sample response
Add a simple pool with resourceTags 
			Sample request
POST account.region.batch.azure.com/pools?api-version=2024-07-01.20.0
{
  "id": "mypool001",
  "vmSize": "STANDARD_DC2s_V2",
  "virtualMachineConfiguration": {
    "imageReference": {
      "publisher": "Canonical",
      "offer": "UbuntuServer",
      "sku": "18_04-lts-gen2",
      "version": "latest"
    },
    "nodeAgentSKUId": "batch.node.ubuntu 18.04"
  },
  "targetDedicatedNodes": 1,
  "resourceTags": {
    "TagName1": "TagValue1",
    "TagName2": "TagValue2"
  }
}
Sample response
Add a VirtualMachineConfiguration pool  
			Sample request
POST account.region.batch.azure.com/pools?api-version=2024-07-01.20.0
{
  "id": "pool2",
  "vmSize": "standard_a1",
  "virtualMachineConfiguration": {
    "imageReference": {
      "publisher": "Canonical",
      "offer": "0001-com-ubuntu-server-focal",
      "sku": "20_04-lts"
    },
    "nodeAgentSKUId": "batch.node.ubuntu 20.04"
  },
  "resizeTimeout": "PT15M",
  "targetDedicatedNodes": 5,
  "targetLowPriorityNodes": 0,
  "taskSlotsPerNode": 3,
  "taskSchedulingPolicy": {
    "nodeFillType": "spread"
  },
  "enableAutoScale": false,
  "enableInterNodeCommunication": true,
  "metadata": [
    {
      "name": "myproperty",
      "value": "myvalue"
    }
  ]
}
Sample response
Add a VirtualMachineConfiguration pool with containers  
			Sample request
POST account.region.batch.azure.com/pools?api-version=2024-07-01.20.0
{
  "id": "pool2",
  "vmSize": "standard_a1",
  "virtualMachineConfiguration": {
    "imageReference": {
      "publisher": "Canonical",
      "offer": "0001-com-ubuntu-server-focal",
      "sku": "120_04-lts"
    },
    "nodeAgentSKUId": "batch.node.ubuntu 20.04",
    "containerConfiguration": {
      "type": "dockerCompatible",
      "containerImageNames": [
        "busybox"
      ]
    }
  },
  "resizeTimeout": "PT15M",
  "targetDedicatedNodes": 5,
  "targetLowPriorityNodes": 0,
  "taskSlotsPerNode": 3,
  "taskSchedulingPolicy": {
    "nodeFillType": "spread"
  },
  "enableAutoScale": false
}
Sample response
Add a VirtualMachineConfiguration pool with extensions  
			Sample request
POST account.region.batch.azure.com/pools?api-version=2024-07-01.20.0
{
  "id": "pool2",
  "vmSize": "standard_a1",
  "virtualMachineConfiguration": {
    "imageReference": {
      "publisher": "Canonical",
      "offer": "0001-com-ubuntu-server-focal",
      "sku": "20_04-lts"
    },
    "nodeAgentSKUId": "batch.node.ubuntu 20.04",
    "extensions": [
      {
        "name": "batchextension1",
        "type": "KeyVaultForLinux",
        "publisher": "Microsoft.Azure.KeyVault",
        "typeHandlerVersion": "2.0",
        "autoUpgradeMinorVersion": true,
        "enableAutomaticUpgrade": true,
        "settings": "{\"secretsManagementSettingsKey\":\"secretsManagementSettingsValue\",\"authenticationSettingsKey\":\"authenticationSettingsValue\"}"
      }
    ]
  },
  "resizeTimeout": "PT15M",
  "targetDedicatedNodes": 5,
  "targetLowPriorityNodes": 0,
  "taskSlotsPerNode": 3,
  "taskSchedulingPolicy": {
    "nodeFillType": "spread"
  },
  "enableAutoScale": false,
  "enableInterNodeCommunication": true,
  "metadata": [
    {
      "name": "myproperty",
      "value": "myvalue"
    }
  ],
  "targetNodeCommunicationMode": "simplified"
}
Sample response
Add a VirtualMachineConfiguration pool with OS disk  
			Sample request
POST account.region.batch.azure.com/pools?api-version=2024-07-01.20.0
{
  "id": "mypool001",
  "vmSize": "standard_d2s_v3",
  "virtualMachineConfiguration": {
    "imageReference": {
      "publisher": "Canonical",
      "offer": "0001-com-ubuntu-server-focal",
      "sku": "20_04-lts"
    },
    "osDisk": {
      "diskSizeGB": 100,
      "managedDisk": {
        "storageAccountType": "standardssd_lrs"
      },
      "caching": "readwrite",
      "ephemeralOSDiskSettings": {
        "placement": "CacheDisk"
      }
    },
    "nodeAgentSKUId": "batch.node.ubuntu 20.04"
  },
  "resizeTimeout": "PT15M",
  "targetDedicatedNodes": 1,
  "targetLowPriorityNodes": 0,
  "taskSlotsPerNode": 1,
  "enableAutoScale": false
}
Sample response
Add a VirtualMachineConfiguration pool with ServiceArtifactReference    
			Sample request
POST account.region.batch.azure.com/pools?api-version=2024-07-01.20.0
{
  "id": "mypool002",
  "vmSize": "Standard_A1_v2",
  "virtualMachineConfiguration": {
    "imageReference": {
      "publisher": "MicrosoftWindowsServer",
      "offer": "WindowsServer",
      "sku": "2016-datacenter-smalldisk",
      "version": "latest"
    },
    "windowsConfiguration": {
      "enableAutomaticUpdates": false
    },
    "serviceArtifactReference": {
      "id": "/subscriptions/subid/resourceGroups/default-azurebatch-japaneast/providers/Microsoft.Compute/galleries/myGallery/serviceArtifacts/myServiceArtifact/vmArtifactsProfiles/vmArtifactsProfile"
    },
    "nodeAgentSKUId": "batch.node.windows amd64"
  },
  "targetDedicatedNodes": 2,
  "upgradePolicy": {
    "mode": "automatic",
    "automaticOSUpgradePolicy": {
      "enableAutomaticOSUpgrade": true
    }
  }
}
Sample response
Definitions
| Name | Description | 
|---|---|
| Application | A reference to an Package to be deployed to Compute Nodes. | 
| Automatic | The configuration parameters used for performing automatic OS upgrade. | 
| Auto | The scope for the auto user | 
| Auto | Specifies the parameters for the auto user that runs a Task on the Batch service. | 
| Azure | Information used to connect to an Azure Storage Container using Blobfuse. | 
| Azure | Information used to connect to an Azure Fileshare. | 
| Batch | An error response received from the Azure Batch service. | 
| Batch | An item of additional information included in an Azure Batch error response. | 
| Caching | The type of caching to enable for the disk. | 
| Certificate | A reference to a Certificate to be installed on Compute Nodes in a Pool. | 
| Certificate | The location of the Certificate store on the Compute Node into which to install the Certificate. | 
| Certificate | Which user Accounts on the Compute Node should have access to the private data of the Certificate. | 
| CIFSMount | Information used to connect to a CIFS file system. | 
| Compute | How Tasks are distributed across Compute Nodes in a Pool. | 
| Compute | The reference to a user assigned identity associated with the Batch pool which a compute node will use. | 
| Container | The configuration for container-enabled Pools. | 
| Container | The entry of path and mount mode you want to mount into task container. | 
| Container | The paths which will be mounted to container task's container. | 
| Container | A private container registry. | 
| Container | The container technology to be used. | 
| Container | The location of the container Task working directory. | 
| Data | Settings which will be used by the data disks associated to Compute Nodes in the Pool. When using attached data disks, you need to mount and format the disks from within a VM to use them. | 
| Diff | Specifies the ephemeral disk placement for operating system disk for all compute nodes (VMs) in the pool. | 
| Diff | Specifies the ephemeral Disk Settings for the operating system disk used by the compute node (VM). | 
| Disk | The disk encryption configuration applied on compute nodes in the pool. Disk encryption configuration is not supported on Linux pool created with Azure Compute Gallery Image. | 
| Disk | The list of disk targets Batch Service will encrypt on the compute node. | 
| Dynamic | The scope of dynamic vnet assignment. | 
| Elevation | The elevation level of the user. | 
| Environment | An environment variable to be set on a Task process. | 
| Error | An error message received in an Azure Batch error response. | 
| Image | A reference to an Azure Virtual Machines Marketplace Image or a Azure Compute Gallery Image. To get the list of all Azure Marketplace Image references verified by Azure Batch, see the 'List Supported Images' operation. | 
| Inbound | The protocol of the endpoint. | 
| Inbound | A inbound NAT Pool that can be used to address specific ports on Compute Nodes in a Batch Pool externally. | 
| IPAddress | The provisioning type for Public IP Addresses for the Pool. | 
| Linux | Properties used to create a user Account on a Linux Compute Node. | 
| Login | The login mode for the user | 
| Managed | |
| Metadata | A name-value pair associated with a Batch service resource. | 
| Mount | The file system to mount on each node. | 
| Network | The network configuration for a Pool. | 
| Network | A network security group rule to apply to an inbound endpoint. | 
| Network | The action that should be taken for a specified IP address, subnet range or tag. | 
| NFSMount | Information used to connect to an NFS file system. | 
| Node | Determines how a pool communicates with the Batch service. | 
| Node | Node placement configuration for a pool. | 
| Node | The placement policy for allocating nodes in the pool. | 
| OSDisk | Settings for the operating system disk of the compute node (VM). | 
| Pool | A Pool in the Azure Batch service to add. | 
| Pool | The endpoint configuration for a Pool. | 
| Public | The public IP Address configuration of the networking configuration of a Pool. | 
| Resource | A single file or multiple files to be downloaded to a Compute Node. | 
| Rolling | The configuration parameters used while performing a rolling upgrade. | 
| Security | Specifies the EncryptionType of the managed disk. It is set to VMGuestStateOnly for encryption of just the VMGuestState blob, and NonPersistedTPM for not persisting firmware state in the VMGuestState blob. Note: It can be set for only Confidential VMs and is required when using Confidential VMs. | 
| Security | Specifies the security profile settings for the virtual machine or virtual machine scale set. | 
| Security | Specifies the SecurityType of the virtual machine. It has to be set to any specified value to enable UefiSettings. | 
| Service | Specifies the service artifact reference id used to set same image version for all virtual machines in the scale set when using 'latest' image version. | 
| Start | A Task which is run when a Node joins a Pool in the Azure Batch service, or when the Compute Node is rebooted or reimaged. | 
| Storage | The storage Account type for use in creating data disks or OS disk. | 
| Task | The container settings for a Task. | 
| Task | Specifies how Tasks should be distributed across Compute Nodes. | 
| Uefi | Specifies the security settings like secure boot and vTPM used while creating the virtual machine. | 
| Upgrade | Specifies the mode of an upgrade to virtual machines in the scale set. | 
| Upgrade | Describes an upgrade policy - automatic, manual, or rolling. | 
| User | Properties used to create a user used to execute Tasks on an Azure Batch Compute Node. | 
| User | The definition of the user identity under which the Task is run. | 
| Virtual | The configuration for Compute Nodes in a Pool based on the Azure Virtual Machines infrastructure. | 
| VMDisk | Specifies the security profile settings for the managed disk. Note: It can only be set for Confidential VMs and required when using Confidential VMs. | 
| VMExtension | The configuration for virtual machine extensions. | 
| Windows | Windows operating system settings to apply to the virtual machine. | 
| Windows | Properties used to create a user Account on a Windows Compute Node. | 
ApplicationPackageReference  
			
			A reference to an Package to be deployed to Compute Nodes.
| Name | Type | Description | 
|---|---|---|
| applicationId | string | The ID of the application to deploy. | 
| version | string | The version of the application to deploy. If omitted, the default version is deployed. | 
AutomaticOSUpgradePolicy  
			
			The configuration parameters used for performing automatic OS upgrade.
| Name | Type | Description | 
|---|---|---|
| disableAutomaticRollback | boolean | Whether OS image rollback feature should be disabled. | 
| enableAutomaticOSUpgrade | boolean | Indicates whether OS upgrades should automatically be applied to scale set instances in a rolling fashion when a newer version of the OS image becomes available.  | 
| osRollingUpgradeDeferral | boolean | Defer OS upgrades on the TVMs if they are running tasks. | 
| useRollingUpgradePolicy | boolean | Indicates whether rolling upgrade policy should be used during Auto OS Upgrade. Auto OS Upgrade will fallback to the default policy if no policy is defined on the VMSS. | 
AutoUserScope  
			
			The scope for the auto user
| Value | Description | 
|---|---|
| task | Specifies that the service should create a new user for the Task. | 
| pool | Specifies that the Task runs as the common auto user Account which is created on every Compute Node in a Pool. | 
AutoUserSpecification  
			
			Specifies the parameters for the auto user that runs a Task on the Batch service.
| Name | Type | Description | 
|---|---|---|
| elevationLevel | The elevation level of the auto user. | |
| scope | The scope for the auto user | 
AzureBlobFileSystemConfiguration    
			
			Information used to connect to an Azure Storage Container using Blobfuse.
| Name | Type | Description | 
|---|---|---|
| accountKey | string | The Azure Storage Account key. | 
| accountName | string | The Azure Storage Account name. | 
| blobfuseOptions | string | Additional command line options to pass to the mount command. | 
| containerName | string | The Azure Blob Storage Container name. | 
| identityReference | The reference to the user assigned identity to use to access containerName | |
| relativeMountPath | string | The relative path on the compute node where the file system will be mounted | 
| sasKey | string | The Azure Storage SAS token. | 
AzureFileShareConfiguration   
			
			Information used to connect to an Azure Fileshare.
| Name | Type | Description | 
|---|---|---|
| accountKey | string | The Azure Storage account key. | 
| accountName | string | The Azure Storage account name. | 
| azureFileUrl | string | The Azure Files URL. | 
| mountOptions | string | Additional command line options to pass to the mount command. | 
| relativeMountPath | string | The relative path on the compute node where the file system will be mounted | 
BatchError 
			
			An error response received from the Azure Batch service.
| Name | Type | Description | 
|---|---|---|
| code | string | An identifier for the error. Codes are invariant and are intended to be consumed programmatically. | 
| message | A message describing the error, intended to be suitable for display in a user interface. | |
| values | A collection of key-value pairs containing additional details about the error. | 
BatchErrorDetail  
			
			An item of additional information included in an Azure Batch error response.
| Name | Type | Description | 
|---|---|---|
| key | string | An identifier specifying the meaning of the Value property. | 
| value | string | The additional information included with the error response. | 
CachingType 
			
			The type of caching to enable for the disk.
| Value | Description | 
|---|---|
| none | The caching mode for the disk is not enabled. | 
| readonly | The caching mode for the disk is read only. | 
| readwrite | The caching mode for the disk is read and write. | 
CertificateReference 
			
			A reference to a Certificate to be installed on Compute Nodes in a Pool.
| Name | Type | Description | 
|---|---|---|
| storeLocation | The location of the Certificate store on the Compute Node into which to install the Certificate. | |
| storeName | string | The name of the Certificate store on the Compute Node into which to install the Certificate. | 
| thumbprint | string | The thumbprint of the Certificate. | 
| thumbprintAlgorithm | string | The algorithm with which the thumbprint is associated. This must be sha1. | 
| visibility | Which user Accounts on the Compute Node should have access to the private data of the Certificate. | 
CertificateStoreLocation  
			
			The location of the Certificate store on the Compute Node into which to install the Certificate.
| Value | Description | 
|---|---|
| currentuser | Certificates should be installed to the CurrentUser Certificate store. | 
| localmachine | Certificates should be installed to the LocalMachine Certificate store. | 
CertificateVisibility 
			
			Which user Accounts on the Compute Node should have access to the private data of the Certificate.
| Value | Description | 
|---|---|
| starttask | The Certificate should be visible to the user account under which the StartTask is run. Note that if AutoUser Scope is Pool for both the StartTask and a Task, this certificate will be visible to the Task as well. | 
| task | The Certificate should be visible to the user accounts under which Job Tasks are run. | 
| remoteuser | The Certificate should be visible to the user accounts under which users remotely access the Compute Node. | 
CIFSMountConfiguration 
			
			Information used to connect to a CIFS file system.
| Name | Type | Description | 
|---|---|---|
| mountOptions | string | Additional command line options to pass to the mount command. | 
| password | string | The password to use for authentication against the CIFS file system. | 
| relativeMountPath | string | The relative path on the compute node where the file system will be mounted | 
| source | string | The URI of the file system to mount. | 
| username | string | The user to use for authentication against the CIFS file system. | 
ComputeNodeFillType   
			
			How Tasks are distributed across Compute Nodes in a Pool.
| Value | Description | 
|---|---|
| spread | Tasks should be assigned evenly across all Compute Nodes in the Pool. | 
| pack | As many Tasks as possible (taskSlotsPerNode) should be assigned to each Compute Node in the Pool before any Tasks are assigned to the next Compute Node in the Pool. | 
ComputeNodeIdentityReference   
			
			The reference to a user assigned identity associated with the Batch pool which a compute node will use.
| Name | Type | Description | 
|---|---|---|
| resourceId | string | The ARM resource id of the user assigned identity. | 
ContainerConfiguration 
			
			The configuration for container-enabled Pools.
| Name | Type | Description | 
|---|---|---|
| containerImageNames | string[] | The collection of container Image names. | 
| containerRegistries | Additional private registries from which containers can be pulled. | |
| type | The container technology to be used. | 
ContainerHostBatchBindMountEntry     
			
			The entry of path and mount mode you want to mount into task container.
| Name | Type | Description | 
|---|---|---|
| isReadOnly | boolean | Mount this source path as read-only mode or not. Default value is false (read/write mode). | 
| source | The path which be mounted to container customer can select. | 
ContainerHostDataPath   
			
			The paths which will be mounted to container task's container.
| Value | Description | 
|---|---|
| Shared | The path for multi-instances task to shared their files. | 
| Startup | The path for start task. | 
| VfsMounts | The path contains all virtual file systems are mounted on this node. | 
| Task | The task path. | 
| JobPrep | The job-prep task path. | 
| Applications | The applications path. | 
ContainerRegistry 
			
			A private container registry.
| Name | Type | Description | 
|---|---|---|
| identityReference | The reference to the user assigned identity to use to access an Azure Container Registry instead of username and password. | |
| password | string | The password to log into the registry server. | 
| registryServer | string | The registry URL. | 
| username | string | The user name to log into the registry server. | 
ContainerType 
			
			The container technology to be used.
| Value | Description | 
|---|---|
| dockerCompatible | A Docker compatible container technology will be used to launch the containers. | 
| criCompatible | A CRI based technology will be used to launch the containers. | 
ContainerWorkingDirectory  
			
			The location of the container Task working directory.
| Value | Description | 
|---|---|
| taskWorkingDirectory | Use the standard Batch service Task working directory, which will contain the Task Resource Files populated by Batch. | 
| containerImageDefault | Use the working directory defined in the container Image. Beware that this directory will not contain the Resource Files downloaded by Batch. | 
DataDisk 
			
			Settings which will be used by the data disks associated to Compute Nodes in the Pool. When using attached data disks, you need to mount and format the disks from within a VM to use them.
| Name | Type | Description | 
|---|---|---|
| caching | The type of caching to be enabled for the data disks. | |
| diskSizeGB | integer (int32) | The initial disk size in gigabytes. | 
| lun | integer (int32) | The logical unit number. | 
| storageAccountType | The storage Account type to be used for the data disk. | 
DiffDiskPlacement  
			
			Specifies the ephemeral disk placement for operating system disk for all compute nodes (VMs) in the pool.
| Value | Description | 
|---|---|
| CacheDisk | The Ephemeral OS Disk is stored on the VM cache. | 
DiffDiskSettings  
			
			Specifies the ephemeral Disk Settings for the operating system disk used by the compute node (VM).
| Name | Type | Description | 
|---|---|---|
| placement | Specifies the ephemeral disk placement for operating system disk for all VMs in the pool. | 
DiskEncryptionConfiguration  
			
			The disk encryption configuration applied on compute nodes in the pool. Disk encryption configuration is not supported on Linux pool created with Azure Compute Gallery Image.
| Name | Type | Description | 
|---|---|---|
| targets | The list of disk targets Batch Service will encrypt on the compute node. | 
DiskEncryptionTarget  
			
			The list of disk targets Batch Service will encrypt on the compute node.
| Value | Description | 
|---|---|
| osdisk | The OS Disk on the compute node is encrypted. | 
| temporarydisk | The temporary disk on the compute node is encrypted. On Linux this encryption applies to other partitions (such as those on mounted data disks) when encryption occurs at boot time. | 
DynamicVNetAssignmentScope   
			
			The scope of dynamic vnet assignment.
| Value | Description | 
|---|---|
| none | No dynamic VNet assignment is enabled. | 
| job | Dynamic VNet assignment is done per-job. | 
ElevationLevel 
			
			The elevation level of the user.
| Value | Description | 
|---|---|
| nonadmin | The user is a standard user without elevated access. | 
| admin | The user is a user with elevated access and operates with full Administrator permissions. | 
EnvironmentSetting 
			
			An environment variable to be set on a Task process.
| Name | Type | Description | 
|---|---|---|
| name | string | The name of the environment variable. | 
| value | string | The value of the environment variable. | 
ErrorMessage 
			
			An error message received in an Azure Batch error response.
| Name | Type | Description | 
|---|---|---|
| lang | string | The language code of the error message | 
| value | string | The text of the message. | 
ImageReference 
			
			A reference to an Azure Virtual Machines Marketplace Image or a Azure Compute Gallery Image. To get the list of all Azure Marketplace Image references verified by Azure Batch, see the 'List Supported Images' operation.
| Name | Type | Description | 
|---|---|---|
| communityGalleryImageId | string | The community gallery image unique identifier | 
| exactVersion | string | The specific version of the platform image or marketplace image used to create the node. This read-only field differs from 'version' only if the value specified for 'version' when the pool was created was 'latest'. | 
| offer | string | The offer type of the Azure Virtual Machines Marketplace Image. | 
| publisher | string | The publisher of the Azure Virtual Machines Marketplace Image. | 
| sharedGalleryImageId | string | The shared gallery image unique identifier | 
| sku | string | The SKU of the Azure Virtual Machines Marketplace Image. | 
| version | string | The version of the Azure Virtual Machines Marketplace Image. | 
| virtualMachineImageId | string | The ARM resource identifier of the Azure Compute Gallery Image. Compute Nodes in the Pool will be created using this Image Id. This is of the form /subscriptions/{subscriptionId}/resourceGroups/{resourceGroup}/providers/Microsoft.Compute/galleries/{galleryName}/images/{imageDefinitionName}/versions/{VersionId} or /subscriptions/{subscriptionId}/resourceGroups/{resourceGroup}/providers/Microsoft.Compute/galleries/{galleryName}/images/{imageDefinitionName} for always defaulting to the latest image version. | 
InboundEndpointProtocol  
			
			The protocol of the endpoint.
| Value | Description | 
|---|---|
| tcp | Use TCP for the endpoint. | 
| udp | Use UDP for the endpoint. | 
InboundNATPool 
			
			A inbound NAT Pool that can be used to address specific ports on Compute Nodes in a Batch Pool externally.
| Name | Type | Description | 
|---|---|---|
| backendPort | integer (int32) | The port number on the Compute Node. | 
| frontendPortRangeEnd | integer (int32) | The last port number in the range of external ports that will be used to provide inbound access to the backendPort on individual Compute Nodes. | 
| frontendPortRangeStart | integer (int32) | The first port number in the range of external ports that will be used to provide inbound access to the backendPort on individual Compute Nodes. | 
| name | string | The name of the endpoint. | 
| networkSecurityGroupRules | A list of network security group rules that will be applied to the endpoint. | |
| protocol | The protocol of the endpoint. | 
IPAddressProvisioningType  
			
			The provisioning type for Public IP Addresses for the Pool.
| Value | Description | 
|---|---|
| batchmanaged | A public IP will be created and managed by Batch. There may be multiple public IPs depending on the size of the Pool. | 
| usermanaged | Public IPs are provided by the user and will be used to provision the Compute Nodes. | 
| nopublicipaddresses | No public IP Address will be created. | 
LinuxUserConfiguration  
			
			Properties used to create a user Account on a Linux Compute Node.
| Name | Type | Description | 
|---|---|---|
| gid | integer (int32) | The group ID for the user Account. | 
| sshPrivateKey | string | The SSH private key for the user Account. | 
| uid | integer (int32) | The user ID of the user Account. | 
LoginMode 
			
			The login mode for the user
| Value | Description | 
|---|---|
| batch | The LOGON32_LOGON_BATCH Win32 login mode. The batch login mode is recommended for long running parallel processes. | 
| interactive | The LOGON32_LOGON_INTERACTIVE Win32 login mode. UAC is enabled on Windows Pools. If this option is used with an elevated user identity in a Windows Pool, the user session will not be elevated unless the application executed by the Task command line is configured to always require administrative privilege or to always require maximum privilege. | 
ManagedDisk 
			
			
				| Name | Type | Description | 
|---|---|---|
| securityProfile | Specifies the security profile settings for the managed disk. | |
| storageAccountType | The storage account type for managed disk. | 
MetadataItem 
			
			A name-value pair associated with a Batch service resource.
| Name | Type | Description | 
|---|---|---|
| name | string | The name of the metadata item. | 
| value | string | The value of the metadata item. | 
MountConfiguration 
			
			The file system to mount on each node.
| Name | Type | Description | 
|---|---|---|
| azureBlobFileSystemConfiguration | The Azure Storage Container to mount using blob FUSE on each node. | |
| azureFileShareConfiguration | The Azure File Share to mount on each node. | |
| cifsMountConfiguration | The CIFS/SMB file system to mount on each node. | |
| nfsMountConfiguration | The NFS file system to mount on each node. | 
NetworkConfiguration 
			
			The network configuration for a Pool.
| Name | Type | Description | 
|---|---|---|
| dynamicVNetAssignmentScope | The scope of dynamic vnet assignment. | |
| enableAcceleratedNetworking | boolean | Whether this pool should enable accelerated networking. | 
| endpointConfiguration | The configuration for endpoints on Compute Nodes in the Batch Pool. | |
| publicIPAddressConfiguration | The Public IPAddress configuration for Compute Nodes in the Batch Pool. | |
| subnetId | string | The ARM resource identifier of the virtual network subnet which the Compute Nodes of the Pool will join. This is of the form /subscriptions/{subscription}/resourceGroups/{group}/providers/{provider}/virtualNetworks/{network}/subnets/{subnet}. | 
NetworkSecurityGroupRule   
			
			A network security group rule to apply to an inbound endpoint.
| Name | Type | Description | 
|---|---|---|
| access | The action that should be taken for a specified IP address, subnet range or tag. | |
| priority | integer (int32) | The priority for this rule. | 
| sourceAddressPrefix | string | The source address prefix or tag to match for the rule. | 
| sourcePortRanges | string[] | The source port ranges to match for the rule. | 
NetworkSecurityGroupRuleAccess    
			
			The action that should be taken for a specified IP address, subnet range or tag.
| Value | Description | 
|---|---|
| allow | Allow access. | 
| deny | Deny access. | 
NFSMountConfiguration 
			
			Information used to connect to an NFS file system.
| Name | Type | Description | 
|---|---|---|
| mountOptions | string | Additional command line options to pass to the mount command. | 
| relativeMountPath | string | The relative path on the compute node where the file system will be mounted | 
| source | string | The URI of the file system to mount. | 
NodeCommunicationMode  
			
			Determines how a pool communicates with the Batch service.
| Value | Description | 
|---|---|
| default | The node communication mode is automatically set by the Batch service. | 
| classic | Nodes using the classic communication mode require inbound TCP communication on ports 29876 and 29877 from the "BatchNodeManagement.{region}" service tag and outbound TCP communication on port 443 to the "Storage.region" and "BatchNodeManagement.{region}" service tags. | 
| simplified | Nodes using the simplified communication mode require outbound TCP communication on port 443 to the "BatchNodeManagement.{region}" service tag. No open inbound ports are required. | 
NodePlacementConfiguration  
			
			Node placement configuration for a pool.
| Name | Type | Description | 
|---|---|---|
| policy | Node placement Policy type on Batch Pools. | 
NodePlacementPolicyType   
			
			The placement policy for allocating nodes in the pool.
| Value | Description | 
|---|---|
| regional | All nodes in the pool will be allocated in the same region. | 
| zonal | Nodes in the pool will be spread across different availability zones with best effort balancing. | 
OSDisk
Settings for the operating system disk of the compute node (VM).
| Name | Type | Description | 
|---|---|---|
| caching | Specifies the caching requirements. Possible values are: None, ReadOnly, ReadWrite. The default values are: None for Standard storage. ReadOnly for Premium storage. | |
| diskSizeGB | integer (int32) | The initial disk size in GB when creating new OS disk. | 
| ephemeralOSDiskSettings | Specifies the ephemeral Disk Settings for the operating system disk used by the compute node (VM). | |
| managedDisk | The managed disk parameters. | |
| writeAcceleratorEnabled | boolean | Specifies whether writeAccelerator should be enabled or disabled on the disk. | 
PoolAddParameter  
			
			A Pool in the Azure Batch service to add.
| Name | Type | Description | 
|---|---|---|
| applicationPackageReferences | The list of Packages to be installed on each Compute Node in the Pool. | |
| autoScaleEvaluationInterval | string (duration) | The time interval at which to automatically adjust the Pool size according to the autoscale formula. | 
| autoScaleFormula | string | A formula for the desired number of Compute Nodes in the Pool. | 
| certificateReferences | The list of Certificates to be installed on each Compute Node in the Pool. Warning: This property is deprecated and will be removed after February, 2024. Please use the Azure KeyVault Extension instead. | |
| displayName | string | The display name for the Pool. | 
| enableAutoScale | boolean | Whether the Pool size should automatically adjust over time. | 
| enableInterNodeCommunication | boolean | Whether the Pool permits direct communication between Compute Nodes. | 
| id | string | A string that uniquely identifies the Pool within the Account. | 
| metadata | A list of name-value pairs associated with the Pool as metadata. | |
| mountConfiguration | Mount storage using specified file system for the entire lifetime of the pool. | |
| networkConfiguration | The network configuration for the Pool. | |
| resizeTimeout | string (duration) | The timeout for allocation of Compute Nodes to the Pool. | 
| resourceTags | object | The user-specified tags associated with the pool. | 
| startTask | A Task specified to run on each Compute Node as it joins the Pool. | |
| targetDedicatedNodes | integer (int32) | The desired number of dedicated Compute Nodes in the Pool. | 
| targetLowPriorityNodes | integer (int32) | The desired number of Spot/Low-priority Compute Nodes in the Pool. | 
| targetNodeCommunicationMode | The desired node communication mode for the pool. | |
| taskSchedulingPolicy | How Tasks are distributed across Compute Nodes in a Pool. | |
| taskSlotsPerNode | integer (int32) | The number of task slots that can be used to run concurrent tasks on a single compute node in the pool. | 
| upgradePolicy | The upgrade policy for the Pool. | |
| userAccounts | The list of user Accounts to be created on each Compute Node in the Pool. | |
| virtualMachineConfiguration | The virtual machine configuration for the Pool. | |
| vmSize | string | The size of virtual machines in the Pool. All virtual machines in a Pool are the same size. | 
PoolEndpointConfiguration  
			
			The endpoint configuration for a Pool.
| Name | Type | Description | 
|---|---|---|
| inboundNATPools | A list of inbound NAT Pools that can be used to address specific ports on an individual Compute Node externally. | 
PublicIPAddressConfiguration  
			
			The public IP Address configuration of the networking configuration of a Pool.
| Name | Type | Description | 
|---|---|---|
| ipAddressIds | string[] | The list of public IPs which the Batch service will use when provisioning Compute Nodes. | 
| provision | The provisioning type for Public IP Addresses for the Pool. | 
ResourceFile 
			
			A single file or multiple files to be downloaded to a Compute Node.
| Name | Type | Description | 
|---|---|---|
| autoStorageContainerName | string | The storage container name in the auto storage Account. | 
| blobPrefix | string | The blob prefix to use when downloading blobs from an Azure Storage container. Only the blobs whose names begin with the specified prefix will be downloaded. | 
| fileMode | string | The file permission mode attribute in octal format. | 
| filePath | string | The location on the Compute Node to which to download the file(s), relative to the Task's working directory. | 
| httpUrl | string | The URL of the file to download. | 
| identityReference | The reference to the user assigned identity to use to access Azure Blob Storage specified by storageContainerUrl or httpUrl | |
| storageContainerUrl | string | The URL of the blob container within Azure Blob Storage. | 
RollingUpgradePolicy  
			
			The configuration parameters used while performing a rolling upgrade.
| Name | Type | Description | 
|---|---|---|
| enableCrossZoneUpgrade | boolean | Allow VMSS to ignore AZ boundaries when constructing upgrade batches. Take into consideration the Update Domain and maxBatchInstancePercent to determine the batch size. This field is able to be set to true or false only when using NodePlacementConfiguration as Zonal. | 
| maxBatchInstancePercent | integer (int32)minimum: 5 maximum: 100 | The maximum percent of total virtual machine instances that will be upgraded simultaneously by the rolling upgrade in one batch. As this is a maximum, unhealthy instances in previous or future batches can cause the percentage of instances in a batch to decrease to ensure higher reliability. The value of this field should be between 5 and 100, inclusive. If both maxBatchInstancePercent and maxUnhealthyInstancePercent are assigned with value, the value of maxBatchInstancePercent should not be more than maxUnhealthyInstancePercent. | 
| maxUnhealthyInstancePercent | integer (int32)minimum: 5 maximum: 100 | The maximum percentage of the total virtual machine instances in the scale set that can be simultaneously unhealthy, either as a result of being upgraded, or by being found in an unhealthy state by the virtual machine health checks before the rolling upgrade aborts. This constraint will be checked prior to starting any batch. The value of this field should be between 5 and 100, inclusive. If both maxBatchInstancePercent and maxUnhealthyInstancePercent are assigned with value, the value of maxBatchInstancePercent should not be more than maxUnhealthyInstancePercent. | 
| maxUnhealthyUpgradedInstancePercent | integer (int32)minimum: 0 maximum: 100 | The maximum percentage of upgraded virtual machine instances that can be found to be in an unhealthy state. This check will happen after each batch is upgraded. If this percentage is ever exceeded, the rolling update aborts. The value of this field should be between 0 and 100, inclusive. | 
| pauseTimeBetweenBatches | string (duration) | The wait time between completing the update for all virtual machines in one batch and starting the next batch. The time duration should be specified in ISO 8601 format. | 
| prioritizeUnhealthyInstances | boolean | Upgrade all unhealthy instances in a scale set before any healthy instances. | 
| rollbackFailedInstancesOnPolicyBreach | boolean | Rollback failed instances to previous model if the Rolling Upgrade policy is violated. | 
SecurityEncryptionTypes  
			
			Specifies the EncryptionType of the managed disk. It is set to VMGuestStateOnly for encryption of just the VMGuestState blob, and NonPersistedTPM for not persisting firmware state in the VMGuestState blob. Note: It can be set for only Confidential VMs and is required when using Confidential VMs.
| Value | Description | 
|---|---|
| NonPersistedTPM | |
| VMGuestStateOnly | 
SecurityProfile 
			
			Specifies the security profile settings for the virtual machine or virtual machine scale set.
| Name | Type | Description | 
|---|---|---|
| encryptionAtHost | boolean | This property can be used by user in the request to enable or disable the Host Encryption for the virtual machine or virtual machine scale set. This will enable the encryption for all the disks including Resource/Temp disk at host itself. For more information on encryption at host requirements, please refer to https://free.blessedness.top/azure/virtual-machines/disk-encryption#supported-vm-sizes. | 
| securityType | Specifies the SecurityType of the virtual machine. It has to be set to any specified value to enable UefiSettings. | |
| uefiSettings | Specifies the security settings like secure boot and vTPM used while creating the virtual machine. | 
SecurityTypes 
			
			Specifies the SecurityType of the virtual machine. It has to be set to any specified value to enable UefiSettings.
| Value | Description | 
|---|---|
| trustedLaunch | Trusted launch protects against advanced and persistent attack techniques. | 
| confidentialVM | Azure confidential computing offers confidential VMs are for tenants with high security and confidentiality requirements. These VMs provide a strong, hardware-enforced boundary to help meet your security needs. You can use confidential VMs for migrations without making changes to your code, with the platform protecting your VM's state from being read or modified. | 
ServiceArtifactReference  
			
			Specifies the service artifact reference id used to set same image version for all virtual machines in the scale set when using 'latest' image version.
| Name | Type | Description | 
|---|---|---|
| id | string | The service artifact reference id of ServiceArtifactReference | 
StartTask 
			
			A Task which is run when a Node joins a Pool in the Azure Batch service, or when the Compute Node is rebooted or reimaged.
| Name | Type | Description | 
|---|---|---|
| commandLine | string | The command line of the StartTask. | 
| containerSettings | The settings for the container under which the StartTask runs. | |
| environmentSettings | A list of environment variable settings for the StartTask. | |
| maxTaskRetryCount | integer (int32) | The maximum number of times the Task may be retried. | 
| resourceFiles | A list of files that the Batch service will download to the Compute Node before running the command line.  There is a maximum size for the list of resource files. When the max size is exceeded, the request will fail and the response error code will be RequestEntityTooLarge. If this occurs, the collection of ResourceFiles must be reduced in size. This can be achieved using .zip files, Application Packages, or Docker Containers. | |
| userIdentity | The user identity under which the StartTask runs. | |
| waitForSuccess | boolean | Whether the Batch service should wait for the StartTask to complete successfully (that is, to exit with exit code 0) before scheduling any Tasks on the Compute Node. | 
StorageAccountType  
			
			The storage Account type for use in creating data disks or OS disk.
| Value | Description | 
|---|---|
| standard_lrs | The data disk / OS disk should use standard locally redundant storage. | 
| premium_lrs | The data disk / OS disk should use premium locally redundant storage. | 
| standardssd_lrs | The data disk / OS disk should use standard SSD locally redundant storage. | 
TaskContainerSettings  
			
			The container settings for a Task.
| Name | Type | Description | 
|---|---|---|
| containerHostBatchBindMounts | The paths you want to mounted to container task. | |
| containerRunOptions | string | Additional options to the container create command. | 
| imageName | string | The Image to use to create the container in which the Task will run. | 
| registry | The private registry which contains the container Image. | |
| workingDirectory | The location of the container Task working directory. | 
TaskSchedulingPolicy  
			
			Specifies how Tasks should be distributed across Compute Nodes.
| Name | Type | Description | 
|---|---|---|
| nodeFillType | How Tasks are distributed across Compute Nodes in a Pool. | 
UefiSettings 
			
			Specifies the security settings like secure boot and vTPM used while creating the virtual machine.
| Name | Type | Description | 
|---|---|---|
| secureBootEnabled | boolean | Specifies whether secure boot should be enabled on the virtual machine. | 
| vTpmEnabled | boolean | Specifies whether vTPM should be enabled on the virtual machine. | 
UpgradeMode 
			
			Specifies the mode of an upgrade to virtual machines in the scale set.
 Possible values are:
 Manual - You  control the application of updates to virtual machines in the scale set. You do this by using the manualUpgrade action.
 Automatic - All virtual machines in the scale set are automatically updated at the same time.
 Rolling - Scale set performs updates in batches with an optional pause time in between.
| Value | Description | 
|---|---|
| automatic | All virtual machines in the scale set are automatically updated at the same time. | 
| manual | You control the application of updates to virtual machines in the scale set. You do this by using the manualUpgrade action. | 
| rolling | The existing instances in a scale set are brought down in batches to be upgraded. Once the upgraded batch is complete, the instances will begin taking traffic again and the next batch will begin. This continues until all instances brought up-to-date. | 
UpgradePolicy 
			
			Describes an upgrade policy - automatic, manual, or rolling.
| Name | Type | Description | 
|---|---|---|
| automaticOSUpgradePolicy | Configuration parameters used for performing automatic OS Upgrade. | |
| mode | Specifies the mode of an upgrade to virtual machines in the scale set. | |
| rollingUpgradePolicy | The configuration parameters used while performing a rolling upgrade. | 
UserAccount 
			
			Properties used to create a user used to execute Tasks on an Azure Batch Compute Node.
| Name | Type | Description | 
|---|---|---|
| elevationLevel | The elevation level of the user Account. | |
| linuxUserConfiguration | The Linux-specific user configuration for the user Account. | |
| name | string | The name of the user Account. Names can contain any Unicode characters up to a maximum length of 20. | 
| password | string | The password for the user Account. | 
| windowsUserConfiguration | The Windows-specific user configuration for the user Account. | 
UserIdentity 
			
			The definition of the user identity under which the Task is run.
| Name | Type | Description | 
|---|---|---|
| autoUser | The auto user under which the Task is run. | |
| username | string | The name of the user identity under which the Task is run. | 
VirtualMachineConfiguration  
			
			The configuration for Compute Nodes in a Pool based on the Azure Virtual Machines infrastructure.
| Name | Type | Description | 
|---|---|---|
| containerConfiguration | The container configuration for the Pool. | |
| dataDisks | 
					Data | The configuration for data disks attached to the Compute Nodes in the Pool. | 
| diskEncryptionConfiguration | The disk encryption configuration for the pool. | |
| extensions | The virtual machine extension for the pool. | |
| imageReference | A reference to the Azure Virtual Machines Marketplace Image or the custom Virtual Machine Image to use. | |
| licenseType | string | The type of on-premises license to be used when deploying the operating system. Windows_Server - The on-premises license is for Windows Server. Windows_Client - The on-premises license is for Windows Client. | 
| nodeAgentSKUId | string | The SKU of the Batch Compute Node agent to be provisioned on Compute Nodes in the Pool. | 
| nodePlacementConfiguration | The node placement configuration for the pool. | |
| osDisk | Settings for the operating system disk of the Virtual Machine. | |
| securityProfile | Specifies the security profile settings for the virtual machine or virtual machine scale set. | |
| serviceArtifactReference | Specifies the service artifact reference id used to set same image version for all virtual machines in the scale set when using 'latest' image version. | |
| windowsConfiguration | Windows operating system settings on the virtual machine. | 
VMDiskSecurityProfile  
			
			Specifies the security profile settings for the managed disk. Note: It can only be set for Confidential VMs and required when using Confidential VMs.
| Name | Type | Description | 
|---|---|---|
| securityEncryptionType | Specifies the EncryptionType of the managed disk. It is set to VMGuestStateOnly for encryption of just the VMGuestState blob, and NonPersistedTPM for not persisting firmware state in the VMGuestState blob. Note: It can be set for only Confidential VMs and is required when using Confidential VMs. | 
VMExtension
The configuration for virtual machine extensions.
| Name | Type | Description | 
|---|---|---|
| autoUpgradeMinorVersion | boolean | Indicates whether the extension should use a newer minor version if one is available at deployment time. Once deployed, however, the extension will not upgrade minor versions unless redeployed, even with this property set to true. | 
| enableAutomaticUpgrade | boolean | Indicates whether the extension should be automatically upgraded by the platform if there is a newer version of the extension available. | 
| name | string | The name of the virtual machine extension. | 
| protectedSettings | object | The extension can contain either protectedSettings or protectedSettingsFromKeyVault or no protected settings at all. | 
| provisionAfterExtensions | string[] | The collection of extension names. | 
| publisher | string | The name of the extension handler publisher. | 
| settings | object | JSON formatted public settings for the extension. | 
| type | string | The type of the extension. | 
| typeHandlerVersion | string | The version of script handler. | 
WindowsConfiguration 
			
			Windows operating system settings to apply to the virtual machine.
| Name | Type | Description | 
|---|---|---|
| enableAutomaticUpdates | boolean | Whether automatic updates are enabled on the virtual machine. | 
WindowsUserConfiguration  
			
			Properties used to create a user Account on a Windows Compute Node.
| Name | Type | Description | 
|---|---|---|
| loginMode | The login mode for the user |