In my earlier Azure Policy post, I covered issues and concerns organizations may face and how many built in Azure policies can address these problems. Now we are going to take it a step further and discuss how to enforce policies and automate their creation. Policies applied at the top level will be inherited by all of the child levels. It is recommended to put best practice policies that cover the entire organization at the Management Group level, and more specific application team policies at the Resource Group level. Try to find a good balance here to ensure you are meeting the policy statements you have defined while also allowing you to easily change policy as required to meet application team requirements as long as they still adhere to core policy rules.
Policy definitions can further be grouped into Initiatives if you have a number of individual policies you want to use as a collection. This helps to reduce the amount of time you need to apply policies individually if they are ultimately trying to achieve a specific initiative. You should group policies into initiatives whenever they are designed to achieve a similar goal or overarching policy statement defined above.
Azure Policy is a great way to have standards in place but there are a few other methods you can use to ensure resource consistency.
You can also use resource locks to prevent accidental deletion of resources. Resource locks have two modes: Read only and Do not delete. Putting a lock on a resource or resource group simply means you need to remove the lock before you can perform those restricted actions on them.
The following are resource lock options:
Learn Module - Quickstart: New policy assignment with Bicep file - Azure Policy | Microsoft Learn
Learn Module - Quickstart: New policy assignment with templates - Azure Policy | Microsoft Learn
Learn Module - Quickstart: New policy assignment with Terraform - Azure Policy | Microsoft Learn
Learn Module - Quickstart: New policy assignment with PowerShell - Azure Policy | Microsoft Learn
Learn Module - Quickstart: New policy assignment with Azure CLI - Azure Policy | Microsoft Learn
If you are already utilizing ARM templates (using Bicep or JSON) and Azure RBAC then Template specs may be something to consider. Below are options to get started:
Users with proper security permissions can have access to your template without making it public and using SAS tokens. The template is essentially storing your ARM template for repeated use. With Template specs you can store them in Azure as a resource and provide versioning vs storing a Bicep module in Git
"When you're deciding between template specs and Bicep modules, a good rule of thumb is: if the template is going to be deployed as is throughout your organization, template specs are probably a good fit. But if you're likely to reuse this template within multiple parent templates, Bicep modules might serve your needs better." - Understand template specs - Training | Microsoft Learn
I went through this Learn module using Bicep and PowerShell. You essentially create a and publish a template spec, learn how to version and update it. You can also give access using Azure's Identity and Access Management (IAM) and learn how to verify deployments.
Make sure you have the latest version of Bicep in VS Code and if you choose to use CLI that Azure CLI is up to date as well.
I hope this helps consolidate your options for keeping your environment up to your standards. Please feel free to add to this list in comments below.
~Amy Colyer
@wyrdgirl
Read more about Azure Policies
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.