不能在不同的订阅中使用日志分析工作区? terraform azurerm 策略分配

问题描述

我正在使用 terraform 将 azure 策略编写为代码 我发现了两个问题 1 我似乎无法使用不同订阅中的日志分析工作区,在同一个订阅中,这很好 2 对于需要托管身份的策略,我似乎无法为其分配正确的权限。

resource "azurerm_policy_assignment" "Enable_Azure_Monitor_for_VMs" {
  
  name                 = "Enable Azure Monitor for VMs"
  scope                = data.azurerm_subscription.current.id
  policy_deFinition_id = "/providers/Microsoft.Authorization/policySetDeFinitions/55f3eceb-5573-4f18-9695-226972c6d74a"
  description          = "Enable Azure Monitor for the virtual machines (VMs) in the specified scope (management group,subscription or resource group). Takes Log Analytics workspace as parameter."
  display_name         = "Enable Azure Monitor for VMs"
  location             = var.location
  Metadata = jsonencode(
    {
      "category" : "General"
  })

  parameters = jsonencode({
    "logAnalytics_1" : {
      "value" : var.log_analytics_workspace_ID
    }
  })

  identity {
    type = "SystemAssigned"
  }

}

resource "azurerm_role_assignment" "vm_policy_msi_assignment" {
  scope                = azurerm_policy_assignment.Enable_Azure_Monitor_for_VMs.scope
  role_deFinition_name = "Contributor"
  principal_id         = azurerm_policy_assignment.Enable_Azure_Monitor_for_VMs.identity[0].principal_id
}

对于 var.log_analytics_workspace_ID,如果我使用与策略在同一订阅中的工作区 ID,它会正常工作。但如果我使用来自不同订阅的工作区 ID,部署后,工作区字段将为空白。

也为

resource "azurerm_role_assignment" "vm_policy_msi_assignment"

,我已经给自己赋予了用户权限管理角色,但是部署后,“此身份当前具有以下权限:”还是空白?

解决方法

我自己的问题得到了答案:) 1 这不是 Azure 中设计好的东西,我认为。 MS 声明“为每个策略分配创建了一个托管标识 (MSI),在定义中包含 DeployIfNotExists 效果。目标分配范围所需的权限是自动管理的。但是,如果修复任务需要与分配之外的资源进行交互范围,您将需要手动配置所需的权限。”

这意味着,需要在另一个订阅的日志分析工作区中访问的系统生成的托管标识需要手动使用日志分析工作区贡献者权限 此外,由于您无法使用用户生成的托管 ID,因此您无法预先填充此 ID。 所以如果你想在terraform中实现,似乎你必须运行两次策略分配,第一次只是获取ID,然后手动(或通过脚本)分配权限,然后再次运行策略分配以指向资源..

2 这个 ID 实际上是被赋予了贡献者的权利,你只需要进入子 RBAC 就能看到它。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...