0

我需要使用 Azure bicep 创建一个虚拟机,其中 OS 磁盘的网络需要设置为私有

在二头肌中:它在磁盘资源下定义,属性“networkAccessPolicy”设置为“AllowPrivate”

在门户中:在磁盘资源页面->网络->私有端点下定义(通过磁盘访问)

方法:

  1. 在虚拟机资源中创建 OS 磁盘,但是我没有设置 networkAccesPolicy 的选项

  2. 在磁盘资源中创建 OS 磁盘,然后附加到虚拟机资源,但是这样我不能指定特定的 'osProfile' 我需要指定它们 osProfile: { computerName: 'string' adminUsername: 'string' adminPassword: '字符串' windowsConfiguration: { provisionVMAgent: bool } }

4

1 回答 1

0

这可以实现,但它不是 Bicep 的一个很好的解决方案因为需要修补 OS 磁盘以关联diskAccess资源,并且这种关联目前不可用 - afaik - 作为ARMBicep中的单独资源。因此,需要一些“二头肌模块跳跃”方法来分阶段实现这种修补。

我为虚拟机扩展了现有vm.bicep模板并为磁盘添加了子网:

...
      {
        name: subnetDiskName
        properties: {
          addressPrefix: subnetDiskPrefix
          privateEndpointNetworkPolicies: 'Disabled'
        }
      }
...

最后,vm.bicep我添加了对该子网的引用,以便可以将其作为参数传递给下一阶段。修补需要分为 2 个阶段/模块:

  1. 再次获取/获取操作系统磁盘作为对象
  2. PATCH / PUT OS磁盘与现有对象数据+对diskAccess资源的引用
...
resource subnetDisk 'Microsoft.Network/virtualNetworks/subnets@2021-02-01' existing = {
  name: subnetDiskName
  parent: vnet
}

module patchDisk 'get-patch-disk.bicep' = {
  name: 'getPatchDisk'
  params: {
    virtualMachineName: virtualMachineName
    diskName: vm.properties.storageProfile.osDisk.name
    location: location
    subnetId: subnetDisk.id
  }
}

对于第 1 阶段get-patch-disk.bicep,只需将当前 OS 磁盘作为对象检索并将其传递:

param virtualMachineName string
param diskName string
param location string = resourceGroup().location
param subnetId string

resource vmDiskGet 'Microsoft.Compute/disks@2020-12-01' existing = {
  name: diskName
}

module vmDiskPatch 'patch-disk.bicep' = {
  name: 'patchDisk'
  params: {
    virtualMachineName: virtualMachineName
    diskName: diskName
    vmDiskGet: vmDiskGet
    location: location
    subnetId: subnetId
  }
}

然后在第 2 阶段patch-disk.bicep创建diskAccess资源,privateEndpoint并将其修补到 OS 磁盘中,方法是从刚刚检索到的对象中传输所有给定属性并添加私有磁盘访问所需的属性。

param virtualMachineName string
param diskName string
param location string = resourceGroup().location
param vmDiskGet object
param subnetId string

var privateEndpointName = 'privateEndpoint${uniqueString(resourceGroup().name)}'
var privateLinkConnectionName = 'privateLink${uniqueString(resourceGroup().name)}'

var diskAccessName = 'diskAccess${uniqueString(resourceGroup().name)}'

resource diskAccess 'Microsoft.Compute/diskAccesses@2020-12-01' = {
  name: diskAccessName
  location: location
  tags: {
    vmName: virtualMachineName
  }
}

resource privateEndpoint 'Microsoft.Network/privateEndpoints@2020-06-01' = {
  name: privateEndpointName
  location: location
  tags: {
    vmName: virtualMachineName
  }
  properties: {
    subnet: {
      id: subnetId
    }
    privateLinkServiceConnections: [
      {
        name: privateLinkConnectionName
        properties: {
          privateLinkServiceId: diskAccess.id
          groupIds: [
            'disks'
          ]
        }
      }
    ]
  }
}

resource vmDiskPut 'Microsoft.Compute/disks@2020-12-01' = {
  name: diskName
  location: vmDiskGet.location
  properties: {
    diskAccessId: diskAccess.id
    networkAccessPolicy: 'AllowPrivate'
    creationData: vmDiskGet.properties.creationData
    diskSizeGB: vmDiskGet.properties.diskSizeGB
  }
}

免责声明

我想更聪明的解决方案是diskAccess在一个二头肌模板中创建资源以及 VM,然后返回diskAccess.idvm.properties.storageProfile.osDisk.name作为输出参数。有了这些输出参数,就可以简单az disk update -n "{diskName}" --network-access-policy AllowPrivate --disk-access "{diskAccessId}"地进行修补。

于 2021-08-05T11:29:19.940 回答