Краткое руководство. Создание и развертывание стека развертывания с помощью Bicep
В этом кратком руководстве описывается создание стека развертывания.
Необходимые компоненты
- Учетная запись Azure с активной подпиской. Создайте учетную запись бесплатно .
- Azure PowerShell версии 12.0.0 или более поздней версии или Azure CLI версии 2.61.0 или более поздней.
- Visual Studio Code с расширением 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. Перейдите в группу ресурсов, в которой развернут стек, и вы можете получить доступ ко всем соответствующим сведениям и параметрам.
Обновление стека развертывания
Чтобы обновить стек развертывания, можно изменить базовый файл 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'
Следующие шаги
Изучите модули Learn для Bicep.