Azure REST Api для создания классической учетной записи модели развертывания
Я пытаюсь создать учетную запись хранения Azure вида: Storage (classic)
через REST API.
Когда я отправляю этот запрос:
PUT https://management.azure.com/subscriptions/{{subscriptionId}}/resourceGroups/{{resourceGroupName}}/providers/Microsoft.Storage/storageAccounts/{{name}}?api-version=2019-04-01
с телом:
{
"sku": {
"name": "Standard_GRS"
},
"kind": "Storage",
"location": "eastus2"
}
Он прекрасно работает, но мое созданное хранилище выглядит так: Storage (general purpose v1)
,
Я пытался отправить запрос с Microsoft.ClassicStorage
вот так:
PUT https://management.azure.com/subscriptions/{{subscriptionId}}/resourceGroups/{{resourceGroupName}}/providers/Microsoft.ClassicStorage/storageAccounts/{{name}}?api-version=2016-11-01
то же тело, что и раньше (а также пытался без "kind"
параметр), и я получаю ответ: 400 Bad Request
{
"error": {
"code": "InvalidStorageAccountRequest",
"message": "The storage account '{{validname}}' request is invalid."
}
}
Любая идея, что должно быть размещено в теле запроса? Или возможно создать хранилище (классическое) через REST API или с помощью кода на C#?
3 ответа
Решение (.NET)
Учетная запись хранения (классическая) не имеет опции "Экспорт шаблона", но ее можно найти в другом месте, как показано ниже:
- Перейти на https://portal.azure.com/
- Создать ресурс (учетная запись хранения)
- Нажмите "Выбрать классическую модель развертывания"
- Выберите вкладку "Просмотр + создание"
- Нажмите "Скачать шаблон для автоматизации"
Вы должны получить два файла JSON:
- параметр.json (здесь вы можете изменить значения параметров):
{
"$schema": "https://schema.management.azure.com/schemas/2015-01-01/deploymentParameters.json#",
"contentVersion": "1.0.0.0",
"parameters": {
"location": {
"value": "westeurope"
},
"storageAccountName": {
"value": "testtemplate"
},
"accountType": {
"value": "Standard_GRS"
}
}
}
- template.json
{
"$schema": "http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#",
"contentVersion": "1.0.0.0",
"parameters": {
"location": {
"type": "string"
},
"storageAccountName": {
"type": "string"
},
"accountType": {
"type": "string"
}
},
"variables": {},
"resources": [
{
"name": "[parameters('storageAccountName')]",
"type": "Microsoft.ClassicStorage/storageAccounts",
"apiVersion": "2016-11-01",
"location": "[parameters('location')]",
"properties": {
"accountType": "[parameters('accountType')]"
},
"dependsOn": []
}
],
"outputs": {}
}
А теперь, чтобы развернуть его, вам просто нужно вставить его ниже, со всеми личными учетными данными (код копируется из учетной записи хранения, вид V2, вкладка "Экспорт шаблона")
// Requires the following Azure NuGet packages and related dependencies:
// package id="Microsoft.Azure.Management.Authorization" version="2.0.0"
// package id="Microsoft.Azure.Management.ResourceManager" version="1.4.0-preview"
// package id="Microsoft.Rest.ClientRuntime.Azure.Authentication" version="2.2.8-preview"
using Microsoft.Azure.Management.ResourceManager;
using Microsoft.Azure.Management.ResourceManager.Models;
using Microsoft.Rest.Azure.Authentication;
using Newtonsoft.Json;
using Newtonsoft.Json.Linq;
using System;
using System.IO;
namespace PortalGenerated
{
/// <summary>
/// This is a helper class for deploying an Azure Resource Manager template
/// More info about template deployments can be found here https://go.microsoft.com/fwLink/?LinkID=733371
/// </summary>
class DeploymentHelper
{
string subscriptionId = "your-subscription-id";
string clientId = "your-service-principal-clientId";
string clientSecret = "your-service-principal-client-secret";
string resourceGroupName = "resource-group-name";
string deploymentName = "deployment-name";
string resourceGroupLocation = "resource-group-location"; // must be specified for creating a new resource group
string pathToTemplateFile = "path-to-template.json-on-disk";
string pathToParameterFile = "path-to-parameters.json-on-disk";
string tenantId = "tenant-id";
public async void Run()
{
// Try to obtain the service credentials
var serviceCreds = await ApplicationTokenProvider.LoginSilentAsync(tenantId, clientId, clientSecret);
// Read the template and parameter file contents
JObject templateFileContents = GetJsonFileContents(pathToTemplateFile);
JObject parameterFileContents = GetJsonFileContents(pathToParameterFile);
// Create the resource manager client
var resourceManagementClient = new ResourceManagementClient(serviceCreds);
resourceManagementClient.SubscriptionId = subscriptionId;
// Create or check that resource group exists
EnsureResourceGroupExists(resourceManagementClient, resourceGroupName, resourceGroupLocation);
// Start a deployment
DeployTemplate(resourceManagementClient, resourceGroupName, deploymentName, templateFileContents, parameterFileContents);
}
/// <summary>
/// Reads a JSON file from the specified path
/// </summary>
/// <param name="pathToJson">The full path to the JSON file</param>
/// <returns>The JSON file contents</returns>
private JObject GetJsonFileContents(string pathToJson)
{
JObject templatefileContent = new JObject();
using (StreamReader file = File.OpenText(pathToJson))
{
using (JsonTextReader reader = new JsonTextReader(file))
{
templatefileContent = (JObject)JToken.ReadFrom(reader);
return templatefileContent;
}
}
}
/// <summary>
/// Ensures that a resource group with the specified name exists. If it does not, will attempt to create one.
/// </summary>
/// <param name="resourceManagementClient">The resource manager client.</param>
/// <param name="resourceGroupName">The name of the resource group.</param>
/// <param name="resourceGroupLocation">The resource group location. Required when creating a new resource group.</param>
private static void EnsureResourceGroupExists(ResourceManagementClient resourceManagementClient, string resourceGroupName, string resourceGroupLocation)
{
if (resourceManagementClient.ResourceGroups.CheckExistence(resourceGroupName) != true)
{
Console.WriteLine(string.Format("Creating resource group '{0}' in location '{1}'", resourceGroupName, resourceGroupLocation));
var resourceGroup = new ResourceGroup();
resourceGroup.Location = resourceGroupLocation;
resourceManagementClient.ResourceGroups.CreateOrUpdate(resourceGroupName, resourceGroup);
}
else
{
Console.WriteLine(string.Format("Using existing resource group '{0}'", resourceGroupName));
}
}
/// <summary>
/// Starts a template deployment.
/// </summary>
/// <param name="resourceManagementClient">The resource manager client.</param>
/// <param name="resourceGroupName">The name of the resource group.</param>
/// <param name="deploymentName">The name of the deployment.</param>
/// <param name="templateFileContents">The template file contents.</param>
/// <param name="parameterFileContents">The parameter file contents.</param>
private static void DeployTemplate(ResourceManagementClient resourceManagementClient, string resourceGroupName, string deploymentName, JObject templateFileContents, JObject parameterFileContents)
{
Console.WriteLine(string.Format("Starting template deployment '{0}' in resource group '{1}'", deploymentName, resourceGroupName));
var deployment = new Deployment();
deployment.Properties = new DeploymentProperties
{
Mode = DeploymentMode.Incremental,
Template = templateFileContents,
Parameters = parameterFileContents["parameters"].ToObject<JObject>()
};
var deploymentResult = resourceManagementClient.Deployments.CreateOrUpdate(resourceGroupName, deploymentName, deployment);
Console.WriteLine(string.Format("Deployment status: {0}", deploymentResult.Properties.ProvisioningState));
}
}
}
Пожалуйста, попробуйте изменить тело запроса на что-то вроде следующего:
{
"properties": {
"accountType": "Standard-GRS"
},
"location": "eastus2"
}
Тип учетной записи для классических учетных записей хранения отличается от новых учетных записей хранения. Они есть Standard-GRS
, Standard-LRS
, Standard-RAGRS
, Standard-ZRS
а также Premium-LRS
,
У меня раньше была такая проблема, и, кажется, это из-за имени, которое вы даете своей учетной записи хранения, но для меня неверный код был одним из следующих:
Код =AccountNameInvalid
Это не действительное имя учетной записи хранения. Имя учетной записи хранения должно быть длиной от 3 до 24 символов и использовать только цифры и строчные буквы.
Вы можете проверить это в ссылке документации Azure.