Поделиться через


Краткое руководство. Создание и развертывание стека развертывания с помощью Bicep

В этом кратком руководстве описывается создание стека развертывания.

Необходимые компоненты

Создание BICEP-файла

Создайте файл Bicep для создания учетной записи хранения и виртуальной сети.

param resourceGroupLocation string = resourceGroup().location
param storageAccountName string = 'store${uniqueString(resourceGroup().id)}'
param vnetName string = 'vnet${uniqueString(resourceGroup().id)}'

resource storageAccount 'Microsoft.Storage/storageAccounts@2023-05-01' = {
  name: storageAccountName
  location: resourceGroupLocation
  kind: 'StorageV2'
  sku: {
    name: 'Standard_LRS'
  }
}

resource virtualNetwork 'Microsoft.Network/virtualNetworks@2024-05-01' = {
  name: vnetName
  location: resourceGroupLocation
  properties: {
    addressSpace: {
      addressPrefixes: [
        '10.0.0.0/16'
      ]
    }
    subnets: [
      {
        name: 'Subnet-1'
        properties: {
          addressPrefix: '10.0.0.0/24'
        }
      }
      {
        name: 'Subnet-2'
        properties: {
          addressPrefix: '10.0.1.0/24'
        }
      }
    ]
  }
}

Сохраните файл Bicep в качестве main.bicep.

Создание стека развертывания

В этом кратком руководстве вы создадите стек развертывания в области группы ресурсов. Вы также можете создать стек развертывания в области подписки или области группы управления. Дополнительные сведения см. в разделе "Создание стеков развертывания".

az group create \
  --name 'demoRg' \
  --location 'centralus'

az stack group create \
  --name demoStack \
  --resource-group 'demoRg' \
  --template-file './main.bicep' \
  --action-on-unmanage 'detachAll' \
  --deny-settings-mode 'none'

Дополнительные сведения и сведения см. в action-on-unmanage deny-setting-modeстеках развертывания.

Проверка развертывания

Чтобы перечислить развернутые стеки развертывания на уровне группы ресурсов:

az stack group show \
  --resource-group 'demoRg' \
  --name 'demoStack'

В выходных данных показаны два управляемых ресурса : одна учетная запись хранения и одна виртуальная сеть:

{
  "actionOnUnmanage": {
    "managementGroups": "detach",
    "resourceGroups": "detach",
    "resources": "detach"
  },
  "bypassStackOutOfSyncError": null,
  "correlationId": "63743f58-a251-4d18-8449-4a37b9885aad",
  "debugSetting": null,
  "deletedResources": [],
  "denySettings": {
    "applyToChildScopes": false,
    "excludedActions": null,
    "excludedPrincipals": null,
    "mode": "none"
  },
  "deploymentId": "/subscriptions/aaaa0a0a-bb1b-cc2c-dd3d-eeeeee4e4e4e/resourceGroups/demoRg/providers/Microsoft.Resources/deployments/demoStack-2501151922xo8",
  "deploymentScope": null,
  "description": null,
  "detachedResources": [],
  "duration": "PT31.9923013S",
  "error": null,
  "failedResources": [],
  "id": "/subscriptions/aaaa0a0a-bb1b-cc2c-dd3d-eeeeee4e4e4e/resourceGroups/demoRg/providers/Microsoft.Resources/deploymentStacks/demoStack",
  "location": null,
  "name": "demoStack",
  "outputs": null,
  "parameters": {},
  "parametersLink": null,
  "provisioningState": "succeeded",
  "resourceGroup": "demoRg",
  "resources": [
    {
      "denyStatus": "none",
      "id": "/subscriptions/aaaa0a0a-bb1b-cc2c-dd3d-eeeeee4e4e4e/resourceGroups/demoRg/providers/Microsoft.Network/virtualNetworks/vnetqci7hnvgit6zm",
      "resourceGroup": "demoRg",
      "status": "managed"
    },
    {
      "denyStatus": "none",
      "id": "/subscriptions/aaaa0a0a-bb1b-cc2c-dd3d-eeeeee4e4e4e/resourceGroups/demoRg/providers/Microsoft.Storage/storageAccounts/storeqci7hnvgit6zm",
      "resourceGroup": "demoRg",
      "status": "managed"
    }
  ],
  "systemData": {
    "createdAt": "2025-01-15T19:07:05.542588+00:00",
    "createdBy": "johndoe@contoso.com",
    "createdByType": "User",
    "lastModifiedAt": "2025-01-15T19:07:05.542588+00:00",
    "lastModifiedBy": "johndoe@contoso.com",
    "lastModifiedByType": "User"
  },
  "tags": {},
  "template": null,
  "templateLink": null,
  "type": "Microsoft.Resources/deploymentStacks"
}

Вы также можете проверить развертывание, перечислив управляемые ресурсы в стеке развертывания:

az stack group show \
  --name 'demoStack' \
  --resource-group 'demoRg' \
  --output 'json'

Выходные данные должны иметь следующий вид:

{
  "actionOnUnmanage": {
    "managementGroups": "detach",
    "resourceGroups": "detach",
    "resources": "detach"
  },
  "bypassStackOutOfSyncError": null,
  "correlationId": "63743f58-a251-4d18-8449-4a37b9885aad",
  "debugSetting": null,
  "deletedResources": [],
  "denySettings": {
    "applyToChildScopes": false,
    "excludedActions": null,
    "excludedPrincipals": null,
    "mode": "none"
  },
  "deploymentId": "/subscriptions/aaaa0a0a-bb1b-cc2c-dd3d-eeeeee4e4e4e/resourceGroups/demoRg/providers/Microsoft.Resources/deployments/demoStack-2501151922xo8",
  "deploymentScope": null,
  "description": null,
  "detachedResources": [],
  "duration": "PT31.9923013S",
  "error": null,
  "failedResources": [],
  "id": "/subscriptions/aaaa0a0a-bb1b-cc2c-dd3d-eeeeee4e4e4e/resourceGroups/demoRg/providers/Microsoft.Resources/deploymentStacks/demoStack",
  "location": null,
  "name": "demoStack",
  "outputs": null,
  "parameters": {},
  "parametersLink": null,
  "provisioningState": "succeeded",
  "resourceGroup": "demoRg",
  "resources": [
    {
      "denyStatus": "none",
      "id": "/subscriptions/aaaa0a0a-bb1b-cc2c-dd3d-eeeeee4e4e4e/resourceGroups/demoRg/providers/Microsoft.Network/virtualNetworks/vnetqci7hnvgit6zm",
      "resourceGroup": "demoRg",
      "status": "managed"
    },
    {
      "denyStatus": "none",
      "id": "/subscriptions/aaaa0a0a-bb1b-cc2c-dd3d-eeeeee4e4e4e/resourceGroups/demoRg/providers/Microsoft.Storage/storageAccounts/storeqci7hnvgit6zm",
      "resourceGroup": "demoRg",
      "status": "managed"
    }
  ],
  "systemData": {
    "createdAt": "2025-01-15T19:07:05.542588+00:00",
    "createdBy": "johndoe@contoso.com",
    "createdByType": "User",
    "lastModifiedAt": "2025-01-15T19:07:05.542588+00:00",
    "lastModifiedBy": "johndoe@contoso.com",
    "lastModifiedByType": "User"
  },
  "tags": {},
  "template": null,
  "templateLink": null,
  "type": "Microsoft.Resources/deploymentStacks"
}

После создания стека можно получить доступ и просмотреть как сам стек, так и управляемые ресурсы, связанные с ним, через портал Azure. Перейдите в группу ресурсов, в которой развернут стек, и вы можете получить доступ ко всем соответствующим сведениям и параметрам.

Снимок экрана: стек развертывания в портал Azure.

Обновление стека развертывания

Чтобы обновить стек развертывания, можно изменить базовый файл Bicep и повторно запустить команду создания стека развертывания.

Измените main.bicep, чтобы изменить имя SKU на Standard_GRS :Standard_LRS

Выполните следующую команду:

az stack group create \
  --name 'demoStack' \
  --resource-group 'demoRg' \
  --template-file './main.bicep' \
  --action-on-unmanage 'detachAll' \
  --deny-settings-mode 'none'

В портал Azure проверьте свойства учетной записи хранения, чтобы подтвердить изменение.

Используя тот же метод, можно добавить ресурс в стек развертывания или удалить управляемый ресурс из стека развертывания. Дополнительные сведения см. в разделе "Добавление ресурсов в стек развертывания" и "Удаление управляемых ресурсов" из стека развертывания.

Удаление стека развертывания

Чтобы удалить стек развертывания и управляемые ресурсы, выполните следующие действия.

az stack group delete \
  --name 'demoStack' \
  --resource-group 'demoRg' \
  --action-on-unmanage 'deleteAll'

Чтобы удалить стек развертывания, но сохраните управляемые ресурсы:

az stack group delete \
  --name 'demoStack' \
  --resource-group 'demoRg' \
  --action-on-unmanage 'detachAll'

Дополнительные сведения см. в разделе "Удаление стеков развертывания".

Команда удаления удаляет исключительно управляемые ресурсы и управляемые группы ресурсов. Вы по-прежнему несете ответственность за удаление групп ресурсов, которые не управляются стеком развертывания.

Очистка ресурсов

Удалите неуправляемую группу ресурсов.

az group delete \
  --name 'demoRg'

Следующие шаги