CLI 示例:使用 Azure Batch 运行作业和任务

此脚本将创建一个批处理作业,并将一系列任务添加到该作业。 它还演示了如何监视作业及其任务。

如果没有 Azure 试用版订阅,请在开始前创建 Azure 试用版订阅

先决条件

  • 如需在本地运行 CLI 参考命令,请安装 Azure CLI。 如果在 Windows 或 macOS 上运行,请考虑在 Docker 容器中运行 Azure CLI。 有关详细信息,请参阅如何在 Docker 容器中运行 Azure CLI

    • 如果使用的是本地安装,请使用 az login 命令登录到 Azure CLI。 若要完成身份验证过程,请遵循终端中显示的步骤。 有关其他登录选项,请参阅使用 Azure CLI 登录

    • 出现提示时,请在首次使用时安装 Azure CLI 扩展。 有关扩展详细信息,请参阅使用 Azure CLI 的扩展

    • 运行 az version 以查找安装的版本和依赖库。 若要升级到最新版本,请运行 az upgrade

示例脚本

在 Batch 服务模式下创建 Batch 帐户

#!/bin/bash

# Create a resource group.
az group create --name myResourceGroup --location chinanorth

# Create a general-purpose storage account in your resource group.
az storage account create \
    --resource-group myResourceGroup \
    --name mystorageaccount \
    --location chinanorth \
    --sku Standard_LRS

# Create a Batch account.
az batch account create \
    --name mybatchaccount \
    --storage-account mystorageaccount \
    --resource-group myResourceGroup \
    --location chinanorth

# Authenticate against the account directly for further CLI interaction.
az batch account login \
    --name mybatchaccount \
    --resource-group myResourceGroup \
    --shared-key-auth

# Create a new Linux pool with a virtual machine configuration. 
az batch pool create \
    --id mypool \
    --vm-size Standard_A1 \
    --target-dedicated 2 \
    --image canonical:ubuntuserver:16.04-LTS \
    --node-agent-sku-id "batch.node.ubuntu 16.04"


# Create a new job to encapsulate the tasks that are added.
az batch job create \
    --id myjob \
    --pool-id mypool

一次添加许多任务

若要一次添加许多任务,请在一个 JSON 文件中指定这些任务,并将该文件传递给命令。 有关格式,请参阅 https://github.com/Azure/azure-docs-cli-python-samples/blob/master/batch/run-job/tasks.json。 请提供该 JSON 文件的绝对路径。 有关示例 JSON 文件,请参阅 https://github.com/Azure-Samples/azure-cli-samples/blob/master/batch/run-job/tasks.json

az batch task create \
    --job-id myjob \
    --json-file tasks.json

更新作业

更新作业,以便在完成所有任务后自动将其标记为已完成。

az batch job set \
--job-id myjob \
--on-all-tasks-complete terminatejob

监视作业的状态

az batch job show --job-id myjob

监视任务的状态

az batch task show \
    --job-id myjob \
    --task-id task1

清理资源

使用 az group delete 命令删除资源组以及与其关联的所有资源 - 除非你持续需要这些资源。 其中一些资源在创建和删除时可能要稍等片刻。

az group delete --name myResourceGroup

示例参考

此脚本使用以下命令。 表中的每条命令链接到特定于命令的文档。

命令 说明
az group create 创建用于存储所有资源的资源组。
az batch account create 创建批处理帐户。
az batch account login 针对指定的批处理帐户进行身份验证,以便进一步进行 CLI 交互。
az batch pool create 创建计算节点池。
az batch job create 创建批处理作业。
az batch task create 将任务添加到指定的批处理作业。
az batch job set 更新批处理作业的属性。
az batch job show 检索指定批处理作业的详细信息。
az batch task show 从指定的批处理作业中检索任务的详细信息。
az group delete 删除资源组,包括所有嵌套的资源。

后续步骤

有关 Azure CLI 的详细信息,请参阅 Azure CLI 文档