Terraform:如何在子网配置中附加 NSG 和服务端点

时间:2020-12-30 20:55:26

标签: terraform terraform-provider-azure

Azurerm 是否可以通过 NSG 附件预配子网并预配服务端点。这是考虑到我们有在子网上强制执行 NSG 的策略。所以 - - 如果子网是一个单独的资源(作为一个单独的资源 nsg_id 不再是一个参数) - 它会使策略失败。

作为 vnet 下的子资源,可以附加 nsg_id - 但没有参数来提供服务端点或服务委托。

1 个答案:

答案 0 :(得分:0)

您可以使用 Terraform 语言 local-exec Provisioner 或 remote-exec 配置程序部署服务端点或服务委托,以在创建资源后调用 PowerShell 或 CLI 脚本。

例如,您可以使用 az network vnet subnet update 为子网启用服务端点。

resource "null_resource" "example" {

   provisioner "local-exec" {

   command = "az network vnet subnet update -g ${azurerm_resource_group.example.name} -n 'subnet1' --vnet-name ${azurerm_virtual_network.example.name} --service-endpoints 'Microsoft.Sql'"
   interpreter = ["PowerShell", "-Command"]
    }  
  
}

enter image description here

有关更多参考,您可以阅读 this blog- Terraform 中的多行 PowerShell。