共用方式為


CLI 範例:使用 Azure Batch 執行作業和工作

此指令碼會建立 Batch 工作,並將一系列作業加入至工作。 它也示範如何監視工作和其作業。

如果您沒有 Azure 帳戶,請在開始之前建立 免費帳戶

先決條件

範例指令碼

啟動 Azure Cloud Shell

Azure Cloud Shell 是免費的互動式 Shell,可讓您用來執行本文中的步驟。 它具有預先安裝和設定的共用 Azure 工具,可與您的帳戶搭配使用。

若要開啟 Cloud Shell,只要選取程式碼區塊右上角的 [試試看] 即可。 您也可以移至 https://shell.azure.com,從另一個瀏覽器索引標籤啟動 Cloud Shell。

當開啟 Cloud Shell 時,請確認已為您的環境選取 Bash。 後續的工作階段將會在 Bash 環境中使用 Azure CLI,請選取 [複製] 以複製程式碼區塊,並將其貼到 Cloud Shell 中,然後按 Enter 鍵加以執行。

登入 Azure

系統會在登入的初始帳戶下自動驗證 Cloud Shell。 使用下列指令碼使用不同的訂用帳戶登入,並將 subscriptionId 取代為您的 Azure 訂用帳戶識別碼。

如果您沒有 Azure 帳戶,請在開始之前建立 免費帳戶

subscription="subscriptionId" # Set Azure subscription ID here

az account set -s $subscription # ...or use 'az login'

如需詳細資訊,請參閱設定使用中訂用帳戶 (部分機器翻譯) 或以互動方式登入 (部分機器翻譯)。

在 Batch 服務模式中建立 Batch 帳戶

# Run a job and tasks with Azure Batch

# Variable block
let "randomIdentifier=$RANDOM*$RANDOM"
location="East US"
[[ "$RESOURCE_GROUP" == '' ]] && resourceGroup="msdocs-batch-rg-$randomIdentifier" || resourceGroup="${RESOURCE_GROUP}"
tag="run-job"
storageAccount="msdocsstorage$randomIdentifier"
batchAccount="msdocsbatch$randomIdentifier"

# Create a resource group.
echo "Creating $resourceGroup in "$location"..."
az group create --name $resourceGroup --location "$location" --tag $tag

# Create a general-purpose storage account in your resource group.
echo "Creating $storageAccount"
az storage account create --resource-group $resourceGroup --name $storageAccount --location "$location" --sku Standard_LRS

# Create a Batch account.
echo "Creating $batchAccount"
az batch account create --name $batchAccount --storage-account $storageAccount --resource-group $resourceGroup --location "$location"

# Authenticate against the account directly for further CLI interaction.
az batch account login --name $batchAccount --resource-group $resourceGroup --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:18_04-lts-gen2 --node-agent-sku-id "batch.node.ubuntu 18.04"

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

# Add tasks to the job. Here the task is a basic shell command.
az batch task create --job-id myjob --task-id task1 --command-line "/bin/bash -c 'printenv AZ_BATCH_TASK_WORKING_DIR'"

一次新增多項工作

若要一次新增多項工作,請在 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 $resourceGroup

範例參考

此指令碼會使用下列命令。 下表中的每個命令都會連結至命令特定的文件。

Command 注意
請輸入命令:az group create 來建立群組。 建立用來存放所有資源的資源群組。
az batch account create(建立批次帳戶) 建立 Batch 帳戶。
az 批次帳戶登入 對指定的 Batch 帳戶驗證以進行進一步的 CLI 互動。
az 批次 集群建立 建立計算節點的集區。
az batch job create 建立 Batch 工作。
az batch task create(批次任務創建) 將作業加入至指定的 Batch 工作。
az 批次作業設定 更新 Batch 工作的屬性。
此命令 az batch job show 用於顯示批次工作的詳細資訊。 擷取指定的 Batch 工作的詳細資料。
az batch 任務顯示 從指定的 Batch 工作擷取作業的詳細資料。
az group delete 刪除資源群組,包括所有的巢狀資源。

後續步驟

如需 Azure CLI 的詳細資訊,請參閱 Azure CLI 文件