Share via


BatchClient.CreatePoolAsync Method

Definition

Overloads

CreatePoolAsync(BatchPoolCreateContent, Nullable<Int32>, Nullable<DateTimeOffset>, CancellationToken)

Creates a Pool to the specified Account.

CreatePoolAsync(RequestContent, Nullable<Int32>, Nullable<DateTimeOffset>, RequestContext)

[Protocol Method] Creates a Pool to the specified Account.

CreatePoolAsync(BatchPoolCreateContent, Nullable<Int32>, Nullable<DateTimeOffset>, CancellationToken)

Source:
BatchClientCustom.cs

Creates a Pool to the specified Account.

public virtual System.Threading.Tasks.Task<Azure.Response> CreatePoolAsync (Azure.Compute.Batch.BatchPoolCreateContent pool, int? timeOutInSeconds = default, DateTimeOffset? ocpdate = default, System.Threading.CancellationToken cancellationToken = default);
abstract member CreatePoolAsync : Azure.Compute.Batch.BatchPoolCreateContent * Nullable<int> * Nullable<DateTimeOffset> * System.Threading.CancellationToken -> System.Threading.Tasks.Task<Azure.Response>
override this.CreatePoolAsync : Azure.Compute.Batch.BatchPoolCreateContent * Nullable<int> * Nullable<DateTimeOffset> * System.Threading.CancellationToken -> System.Threading.Tasks.Task<Azure.Response>
Public Overridable Function CreatePoolAsync (pool As BatchPoolCreateContent, Optional timeOutInSeconds As Nullable(Of Integer) = Nothing, Optional ocpdate As Nullable(Of DateTimeOffset) = Nothing, Optional cancellationToken As CancellationToken = Nothing) As Task(Of Response)

Parameters

pool
BatchPoolCreateContent

The Pool to be created.

timeOutInSeconds
Nullable<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.".

ocpdate
Nullable<DateTimeOffset>

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.

cancellationToken
CancellationToken

The cancellation token to use.

Returns

Exceptions

pool is null.

Examples

This sample shows how to call CreatePoolAsync.

Uri endpoint = new Uri("<https://my-service.azure.com>");
TokenCredential credential = new DefaultAzureCredential();
BatchClient client = new BatchClient(endpoint, credential);

BatchPoolCreateContent pool = new BatchPoolCreateContent("<id>", "<vmSize>");
Response response = await client.CreatePoolAsync(pool);

This sample shows how to call CreatePoolAsync with all parameters.

Uri endpoint = new Uri("<https://my-service.azure.com>");
TokenCredential credential = new DefaultAzureCredential();
BatchClient client = new BatchClient(endpoint, credential);

BatchPoolCreateContent pool = new BatchPoolCreateContent("<id>", "<vmSize>")
{
    DisplayName = "<displayName>",
    VirtualMachineConfiguration = new VirtualMachineConfiguration(new ImageReference
    {
        Publisher = "<publisher>",
        Offer = "<offer>",
        Sku = "<sku>",
        Version = "<version>",
        VirtualMachineImageId = "<virtualMachineImageId>",
    }, "<nodeAgentSKUId>")
    {
        WindowsConfiguration = new WindowsConfiguration
        {
            EnableAutomaticUpdates = true,
        },
        DataDisks = {new DataDisk(1234, 1234)
        {
            Caching = CachingType.None,
            StorageAccountType = StorageAccountType.StandardLRS,
        }},
        LicenseType = "<licenseType>",
        ContainerConfiguration = new ContainerConfiguration(ContainerType.DockerCompatible)
        {
            ContainerImageNames = { "<containerImageNames>" },
            ContainerRegistries = {new ContainerRegistryReference
            {
                Username = "<username>",
                Password = "<password>",
                RegistryServer = "<registryServer>",
                IdentityReference = new BatchNodeIdentityReference
                {
                    ResourceId = "<resourceId>",
                },
            }},
        },
        DiskEncryptionConfiguration = new DiskEncryptionConfiguration
        {
            Targets = { DiskEncryptionTarget.OsDisk },
        },
        NodePlacementConfiguration = new BatchNodePlacementConfiguration
        {
            Policy = BatchNodePlacementPolicyType.Regional,
        },
        Extensions = {new VMExtension("<name>", "<publisher>", "<type>")
        {
            TypeHandlerVersion = "<typeHandlerVersion>",
            AutoUpgradeMinorVersion = true,
            EnableAutomaticUpgrade = true,
            Settings =
            {
                ["key"] = "<settings>"
            },
            ProtectedSettings =
            {
                ["key"] = "<protectedSettings>"
            },
            ProvisionAfterExtensions = {"<provisionAfterExtensions>"},
        }},
        OsDisk = new OSDisk
        {
            EphemeralOSDiskSettings = new DiffDiskSettings
            {
                Placement = DiffDiskPlacement.CacheDisk,
            },
            Caching = CachingType.None,
            DiskSizeGB = 1234,
            ManagedDisk = new ManagedDisk(StorageAccountType.StandardLRS),
            WriteAcceleratorEnabled = true,
        },
        SecurityProfile = new SecurityProfile(true, SecurityTypes.TrustedLaunch, new UefiSettings
        {
            SecureBootEnabled = true,
            VTpmEnabled = true,
        }),
        ServiceArtifactReference = new ServiceArtifactReference("<id>"),
    },
    ResizeTimeout = XmlConvert.ToTimeSpan("PT1H23M45S"),
    ResourceTags =
    {
        ["key"] = "<resourceTags>"
    },
    TargetDedicatedNodes = 1234,
    TargetLowPriorityNodes = 1234,
    EnableAutoScale = true,
    AutoScaleFormula = "<autoScaleFormula>",
    AutoScaleEvaluationInterval = XmlConvert.ToTimeSpan("PT1H23M45S"),
    EnableInterNodeCommunication = true,
    NetworkConfiguration = new NetworkConfiguration
    {
        SubnetId = "<subnetId>",
        DynamicVNetAssignmentScope = DynamicVNetAssignmentScope.None,
        EndpointConfiguration = new BatchPoolEndpointConfiguration(new InboundNatPool[]
        {
            new InboundNatPool("<name>", InboundEndpointProtocol.Tcp, 1234, 1234, 1234)
            {
                NetworkSecurityGroupRules = {new NetworkSecurityGroupRule(1234, NetworkSecurityGroupRuleAccess.Allow, "<sourceAddressPrefix>")
                {
                    SourcePortRanges = {"<sourcePortRanges>"},
                }},
            }
        }),
        PublicIpAddressConfiguration = new PublicIpAddressConfiguration
        {
            IpAddressProvisioningType = IpAddressProvisioningType.BatchManaged,
            IpAddressIds = { "<ipAddressIds>" },
        },
        EnableAcceleratedNetworking = true,
    },
    StartTask = new BatchStartTask("<commandLine>")
    {
        ContainerSettings = new BatchTaskContainerSettings("<imageName>")
        {
            ContainerRunOptions = "<containerRunOptions>",
            Registry = default,
            WorkingDirectory = ContainerWorkingDirectory.TaskWorkingDirectory,
        },
        ResourceFiles = {new ResourceFile
        {
            AutoStorageContainerName = "<autoStorageContainerName>",
            StorageContainerUrl = "<storageContainerUrl>",
            HttpUrl = "<httpUrl>",
            BlobPrefix = "<blobPrefix>",
            FilePath = "<filePath>",
            FileMode = "<fileMode>",
            IdentityReference = default,
        }},
        EnvironmentSettings = {new EnvironmentSetting("<name>")
        {
            Value = "<value>",
        }},
        UserIdentity = new UserIdentity
        {
            Username = "<username>",
            AutoUser = new AutoUserSpecification
            {
                Scope = AutoUserScope.Task,
                ElevationLevel = ElevationLevel.NonAdmin,
            },
        },
        MaxTaskRetryCount = 1234,
        WaitForSuccess = true,
    },
    ApplicationPackageReferences = {new BatchApplicationPackageReference("<applicationId>")
    {
        Version = "<version>",
    }},
    TaskSlotsPerNode = 1234,
    TaskSchedulingPolicy = new BatchTaskSchedulingPolicy(BatchNodeFillType.Spread),
    UserAccounts = {new UserAccount("<name>", "<password>")
    {
        ElevationLevel = ElevationLevel.NonAdmin,
        LinuxUserConfiguration = new LinuxUserConfiguration
        {
            Uid = 1234,
            Gid = 1234,
            SshPrivateKey = "<sshPrivateKey>",
        },
        WindowsUserConfiguration = new WindowsUserConfiguration
        {
            LoginMode = LoginMode.Batch,
        },
    }},
    Metadata = { new MetadataItem("<name>", "<value>") },
    MountConfiguration = {new MountConfiguration
    {
        AzureBlobFileSystemConfiguration = new AzureBlobFileSystemConfiguration("<accountName>", "<containerName>", "<relativeMountPath>")
        {
            AccountKey = "<accountKey>",
            SasKey = "<sasKey>",
            BlobfuseOptions = "<blobfuseOptions>",
            IdentityReference = default,
        },
        NfsMountConfiguration = new NfsMountConfiguration("<source>", "<relativeMountPath>")
        {
            MountOptions = "<mountOptions>",
        },
        CifsMountConfiguration = new CifsMountConfiguration("<username>", "<source>", "<relativeMountPath>", "<password>")
        {
            MountOptions = "<mountOptions>",
        },
        AzureFileShareConfiguration = new AzureFileShareConfiguration("<accountName>", "<azureFileUrl>", "<accountKey>", "<relativeMountPath>")
        {
            MountOptions = "<mountOptions>",
        },
    }},
    TargetNodeCommunicationMode = BatchNodeCommunicationMode.Default,
    UpgradePolicy = new UpgradePolicy(UpgradeMode.Automatic)
    {
        AutomaticOsUpgradePolicy = new AutomaticOsUpgradePolicy
        {
            DisableAutomaticRollback = true,
            EnableAutomaticOsUpgrade = true,
            UseRollingUpgradePolicy = true,
            OsRollingUpgradeDeferral = true,
        },
        RollingUpgradePolicy = new RollingUpgradePolicy
        {
            EnableCrossZoneUpgrade = true,
            MaxBatchInstancePercent = 1234,
            MaxUnhealthyInstancePercent = 1234,
            MaxUnhealthyUpgradedInstancePercent = 1234,
            PauseTimeBetweenBatches = XmlConvert.ToTimeSpan("PT1H23M45S"),
            PrioritizeUnhealthyInstances = true,
            RollbackFailedInstancesOnPolicyBreach = true,
        },
    },
};
Response response = await client.CreatePoolAsync(pool, timeOutInSeconds: 1234, ocpdate: DateTimeOffset.Parse("Tue, 10 May 2022 18:57:31 GMT"));

Remarks

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.

Applies to

CreatePoolAsync(RequestContent, Nullable<Int32>, Nullable<DateTimeOffset>, RequestContext)

Source:
BatchClientCustom.cs

[Protocol Method] Creates a Pool to the specified Account.

public virtual System.Threading.Tasks.Task<Azure.Response> CreatePoolAsync (Azure.Core.RequestContent content, int? timeOutInSeconds = default, DateTimeOffset? ocpdate = default, Azure.RequestContext context = default);
abstract member CreatePoolAsync : Azure.Core.RequestContent * Nullable<int> * Nullable<DateTimeOffset> * Azure.RequestContext -> System.Threading.Tasks.Task<Azure.Response>
override this.CreatePoolAsync : Azure.Core.RequestContent * Nullable<int> * Nullable<DateTimeOffset> * Azure.RequestContext -> System.Threading.Tasks.Task<Azure.Response>
Public Overridable Function CreatePoolAsync (content As RequestContent, Optional timeOutInSeconds As Nullable(Of Integer) = Nothing, Optional ocpdate As Nullable(Of DateTimeOffset) = Nothing, Optional context As RequestContext = Nothing) As Task(Of Response)

Parameters

content
RequestContent

The content to send as the body of the request.

timeOutInSeconds
Nullable<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.".

ocpdate
Nullable<DateTimeOffset>

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.

context
RequestContext

The request context, which can override default behaviors of the client pipeline on a per-call basis.

Returns

The response returned from the service.

Exceptions

content is null.

Service returned a non-success status code.

Examples

This sample shows how to call CreatePoolAsync.

Uri endpoint = new Uri("<https://my-service.azure.com>");
TokenCredential credential = new DefaultAzureCredential();
BatchClient client = new BatchClient(endpoint, credential);

using RequestContent content = RequestContent.Create(new
{
    id = "<id>",
    vmSize = "<vmSize>",
});
Response response = await client.CreatePoolAsync(content);

Console.WriteLine(response.Status);

This sample shows how to call CreatePoolAsync with all parameters and request content.

Uri endpoint = new Uri("<https://my-service.azure.com>");
TokenCredential credential = new DefaultAzureCredential();
BatchClient client = new BatchClient(endpoint, credential);

using RequestContent content = RequestContent.Create(new
{
    id = "<id>",
    displayName = "<displayName>",
    vmSize = "<vmSize>",
    virtualMachineConfiguration = new
    {
        imageReference = new
        {
            publisher = "<publisher>",
            offer = "<offer>",
            sku = "<sku>",
            version = "<version>",
            virtualMachineImageId = "<virtualMachineImageId>",
        },
        nodeAgentSKUId = "<nodeAgentSKUId>",
        windowsConfiguration = new
        {
            enableAutomaticUpdates = true,
        },
        dataDisks = new object[]
        {
            new
            {
                lun = 1234,
                caching = "none",
                diskSizeGB = 1234,
                storageAccountType = "standard_lrs",
            }
        },
        licenseType = "<licenseType>",
        containerConfiguration = new
        {
            type = "dockerCompatible",
            containerImageNames = new object[]
            {
                "<containerImageNames>"
            },
            containerRegistries = new object[]
            {
                new
                {
                    username = "<username>",
                    password = "<password>",
                    registryServer = "<registryServer>",
                    identityReference = new
                    {
                        resourceId = "<resourceId>",
                    },
                }
            },
        },
        diskEncryptionConfiguration = new
        {
            targets = new object[]
            {
                "osdisk"
            },
        },
        nodePlacementConfiguration = new
        {
            policy = "regional",
        },
        extensions = new object[]
        {
            new
            {
                name = "<name>",
                publisher = "<publisher>",
                type = "<type>",
                typeHandlerVersion = "<typeHandlerVersion>",
                autoUpgradeMinorVersion = true,
                enableAutomaticUpgrade = true,
                settings = new
                {
                    key = "<settings>",
                },
                protectedSettings = new
                {
                    key = "<protectedSettings>",
                },
                provisionAfterExtensions = new object[]
                {
                    "<provisionAfterExtensions>"
                },
            }
        },
        osDisk = new
        {
            ephemeralOSDiskSettings = new
            {
                placement = "cachedisk",
            },
            caching = "none",
            diskSizeGB = 1234,
            managedDisk = new
            {
                storageAccountType = "standard_lrs",
            },
            writeAcceleratorEnabled = true,
        },
        securityProfile = new
        {
            encryptionAtHost = true,
            securityType = "trustedLaunch",
            uefiSettings = new
            {
                secureBootEnabled = true,
                vTpmEnabled = true,
            },
        },
        serviceArtifactReference = new
        {
            id = "<id>",
        },
    },
    resizeTimeout = "PT1H23M45S",
    resourceTags = new
    {
        key = "<resourceTags>",
    },
    targetDedicatedNodes = 1234,
    targetLowPriorityNodes = 1234,
    enableAutoScale = true,
    autoScaleFormula = "<autoScaleFormula>",
    autoScaleEvaluationInterval = "PT1H23M45S",
    enableInterNodeCommunication = true,
    networkConfiguration = new
    {
        subnetId = "<subnetId>",
        dynamicVNetAssignmentScope = "none",
        endpointConfiguration = new
        {
            inboundNATPools = new object[]
            {
                new
                {
                    name = "<name>",
                    protocol = "tcp",
                    backendPort = 1234,
                    frontendPortRangeStart = 1234,
                    frontendPortRangeEnd = 1234,
                    networkSecurityGroupRules = new object[]
                    {
                        new
                        {
                            priority = 1234,
                            access = "allow",
                            sourceAddressPrefix = "<sourceAddressPrefix>",
                            sourcePortRanges = new object[]
                            {
                                "<sourcePortRanges>"
                            },
                        }
                    },
                }
            },
        },
        publicIPAddressConfiguration = new
        {
            provision = "batchmanaged",
            ipAddressIds = new object[]
            {
                "<ipAddressIds>"
            },
        },
        enableAcceleratedNetworking = true,
    },
    startTask = new
    {
        commandLine = "<commandLine>",
        containerSettings = new
        {
            containerRunOptions = "<containerRunOptions>",
            imageName = "<imageName>",
            workingDirectory = "taskWorkingDirectory",
        },
        resourceFiles = new object[]
        {
            new
            {
                autoStorageContainerName = "<autoStorageContainerName>",
                storageContainerUrl = "<storageContainerUrl>",
                httpUrl = "<httpUrl>",
                blobPrefix = "<blobPrefix>",
                filePath = "<filePath>",
                fileMode = "<fileMode>",
            }
        },
        environmentSettings = new object[]
        {
            new
            {
                name = "<name>",
                value = "<value>",
            }
        },
        userIdentity = new
        {
            username = "<username>",
            autoUser = new
            {
                scope = "task",
                elevationLevel = "nonadmin",
            },
        },
        maxTaskRetryCount = 1234,
        waitForSuccess = true,
    },
    applicationPackageReferences = new object[]
    {
        new
        {
            applicationId = "<applicationId>",
            version = "<version>",
        }
    },
    taskSlotsPerNode = 1234,
    taskSchedulingPolicy = new
    {
        nodeFillType = "spread",
    },
    userAccounts = new object[]
    {
        new
        {
            name = "<name>",
            password = "<password>",
            elevationLevel = "nonadmin",
            linuxUserConfiguration = new
            {
                uid = 1234,
                gid = 1234,
                sshPrivateKey = "<sshPrivateKey>",
            },
            windowsUserConfiguration = new
            {
                loginMode = "batch",
            },
        }
    },
    metadata = new object[]
    {
        new
        {
            name = "<name>",
            value = "<value>",
        }
    },
    mountConfiguration = new object[]
    {
        new
        {
            azureBlobFileSystemConfiguration = new
            {
                accountName = "<accountName>",
                containerName = "<containerName>",
                accountKey = "<accountKey>",
                sasKey = "<sasKey>",
                blobfuseOptions = "<blobfuseOptions>",
                relativeMountPath = "<relativeMountPath>",
            },
            nfsMountConfiguration = new
            {
                source = "<source>",
                relativeMountPath = "<relativeMountPath>",
                mountOptions = "<mountOptions>",
            },
            cifsMountConfiguration = new
            {
                username = "<username>",
                source = "<source>",
                relativeMountPath = "<relativeMountPath>",
                mountOptions = "<mountOptions>",
                password = "<password>",
            },
            azureFileShareConfiguration = new
            {
                accountName = "<accountName>",
                azureFileUrl = "<azureFileUrl>",
                accountKey = "<accountKey>",
                relativeMountPath = "<relativeMountPath>",
                mountOptions = "<mountOptions>",
            },
        }
    },
    targetNodeCommunicationMode = "default",
    upgradePolicy = new
    {
        mode = "automatic",
        automaticOSUpgradePolicy = new
        {
            disableAutomaticRollback = true,
            enableAutomaticOSUpgrade = true,
            useRollingUpgradePolicy = true,
            osRollingUpgradeDeferral = true,
        },
        rollingUpgradePolicy = new
        {
            enableCrossZoneUpgrade = true,
            maxBatchInstancePercent = 1234,
            maxUnhealthyInstancePercent = 1234,
            maxUnhealthyUpgradedInstancePercent = 1234,
            pauseTimeBetweenBatches = "PT1H23M45S",
            prioritizeUnhealthyInstances = true,
            rollbackFailedInstancesOnPolicyBreach = true,
        },
    },
});
Response response = await client.CreatePoolAsync(content, timeOutInSeconds: 1234, ocpdate: DateTimeOffset.Parse("Tue, 10 May 2022 18:57:31 GMT"));

Console.WriteLine(response.Status);

Applies to