Azure Resource Manager テンプレート (ARM テンプレート) をデプロイする場合は、各リソースの場所を指定する必要があります。 場所は、リソース グループの場所と同じである必要はありません。
利用可能な場所を取得する
場所ごとに、異なるリソースの種類がサポートされます。 リソースの種類にサポートされている場所を取得するには、Azure PowerShell または Azure CLI を使用します。
((Get-AzResourceProvider -ProviderNamespace Microsoft.Batch).ResourceTypes `
| Where-Object ResourceTypeName -eq batchAccounts).Locations
ロケーション パラメーターを使用する
テンプレートを柔軟にデプロイするには、パラメーターを使用してリソースの場所を指定します。 パラメータのデフォルト値を resourceGroup().location
に設定します。
次の例は、パラメーターとして指定された場所にデプロイされるストレージ アカウントを示しています。
{
"$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
"contentVersion": "1.0.0.0",
"parameters": {
"storageAccountType": {
"type": "string",
"defaultValue": "Standard_LRS",
"allowedValues": [
"Standard_LRS",
"Standard_GRS",
"Standard_ZRS",
"Premium_LRS"
],
"metadata": {
"description": "Storage Account type"
}
},
"location": {
"type": "string",
"defaultValue": "[resourceGroup().location]",
"metadata": {
"description": "Location for all resources."
}
}
},
"variables": {
"storageAccountName": "[format('storage{0}', uniqueString(resourceGroup().id))]"
},
"resources": [
{
"type": "Microsoft.Storage/storageAccounts",
"apiVersion": "2022-09-01",
"name": "[variables('storageAccountName')]",
"location": "[parameters('location')]",
"sku": {
"name": "[parameters('storageAccountType')]"
},
"kind": "StorageV2",
"properties": {}
}
],
"outputs": {
"storageAccountName": {
"type": "string",
"value": "[variables('storageAccountName')]"
}
}
}
次のステップ
- テンプレート関数の完全な一覧については、「ARM テンプレート関数」を参照してください。
- テンプレート ファイルの詳細については、「ARM テンプレートの構造と構文の詳細」を参照してください。