【Azure Policy】当Azure策略组中存在多个修正任务时候时的批量处理办法

问题描述

在分配一组策略中包含了很多修正任务时候,从门户上,只能选择一个修正任务执行。

如下图:

是否有好的办法,执行全部的修正任务呢?

 

问题解答

从Azure门户的设计来看,只能选择一个修正任务是设计使然。如果想批量执行全部的修正任务,需要使用PowerShell脚本来循环执行。

详细步骤:

第一步:设置分配ID(Assignment ID)参数

在门户上Assignment ID的全部内容格式为:/subscriptions/{subscriptions id}/providers/microsoft.authorization/policyassignments/f2c53c0fe9af0eb6e223041f,最后一部分{policyassignments/{Assignment ID}}就是脚本中所使用的Assignment ID

$InitiativeAssignmentID = "<myInitiativeAssignment>"

 

第二步:获取不合规策略的修正任务列表

根据Assignment ID过滤策略中使用 deployIfNotExists ,modify,append 的策略信息

$RemediatablePolicies = Get-AzPolicyState | Where-Object { $_.PolicyAssignmentName -eq $InitiativeAssignmentID -and ($_.PolicyDefinitionAction -eq "deployIfNotExists" -or $_.PolicyDefinitionAction -eq "modify" -or $_.PolicyDefinitionAction -eq "append") } | select-object PolicyDefinitionReferenceId, PolicyAssignmentId -Unique

 

第三步:循环创建修正任务

foreach ($policy in $RemediatablePolicies) {
   $remediationName = "rem." + $policy.PolicyDefinitionReferenceId
   Start-AzPolicyRemediation -Name $remediationName -PolicyAssignmentId $policy.PolicyAssignmentId -PolicyDefinitionReferenceId $policy.PolicyDefinitionReferenceId -ResourceDiscoveryMode ReEvaluateCompliance
}

 

执行后的效果如下图:

 

 

 

 

参考资料

Automating Azure Remediation for Policy Initiatives with Azure PowerShell : https://techcommunity.microsoft.com/blog/azurepaasblog/automating-azure-remediation-for-policy-initiatives-with-azure-powershell/4113485

 

posted @   路边两盏灯  阅读(7)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
历史上的今天:
2023-02-06 【Azure 应用服务】在App Service中新建WebJob时候遇见错误,不能成功创建新的工作任务
点击右上角即可分享
微信分享提示