In your Azure environment, there could be several critical Azure resources that you don’t ever want to be deleted or modified. For an instance, deleting a SQL Azure resource, or deleting any running services from the Azure portal. Of course, no one just really doesn’t want to do it. Nevertheless, it may get deleted or modified by chance, or as an administrator or owner of the solution you want to prevent the delete or change access to other users of the same subscription or resources. You can take help of Azure Resource Locking. This will help you by ‘locking down‘ a resource or a resource group all together to prevent accidentally modifying or deleting it.
Preventing Azure Resource Deletion – Locking Azure Resource
From the Azure Portal, Open the respective Azure Resource you want to lock. In this case, we choose one Cosmos DB resource and select the Locks option from the Settings category.
data:image/s3,"s3://crabby-images/22ce1/22ce1672610e3ab9dc8b0d85a62c2f324b12f2e4" alt="Add Lock Azure Resource"
Provide a Lock name and choose the type of Lock. The lock type you can choose here it to make it read-only or restrict delete access. Let’s choose “Delete” lock and provide some additional notes for future references.
data:image/s3,"s3://crabby-images/6e98a/6e98a32e0574f1375e2abe445418aab540499994" alt="Lock Details for Azure Lock"
Once the above information is filled. Click on OK to proceed with Lock creation.
Once the lock is created, you can see the details of Locks as shown in the below screenshot.
data:image/s3,"s3://crabby-images/f5f29/f5f29738beaf5bd4bd723dbbd3c18d7e36533418" alt="Lock Created with Resource Scope"
Once the lock is in placed, if you and anyone who has the access to this resource try to delete it, will get a Delete Failure notification.
data:image/s3,"s3://crabby-images/cb6d5/cb6d525e4978234702176a566fb34aa999f9efbc" alt="Failed To Delete Locked Azure Resources"
You need to unlock the resource before you delete. The same goes for making a read-only lock as well.
Locking Azure Resource Group
The scope of the above lock was set to “This Resource”, which mean only that attached resource is bounded with the lock. There are cases you may lock your entire resource group which is running on production. In that case, you can lock the entire resource group. It will cascade the effects to all its child resources.
data:image/s3,"s3://crabby-images/783b5/783b57f2a1edde6be18561310ed6311bca70fe31" alt="Preventing Azure Resource Deletion : Locking a Resource Group"
Once the lock is created, if you check for the scope of this lock – it is set to “Resource Group”
data:image/s3,"s3://crabby-images/873ff/873ff2833f94987457efd162ec2e2bbfc1234a03" alt="Preventing Azure Resource Deletion : Resource Group Locking Scope"
Now if you try to delete the resource group you will get a similar message like what you received for Resources
data:image/s3,"s3://crabby-images/234c6/234c6d4e06c53933448a89efb1e45449899129fc" alt="Preventing Azure Resource Deletion : Deleting Prevention of Resource Group"
When the lock is set to “Resource Group”, if you try to delete any resources under that group you will receive following error.
data:image/s3,"s3://crabby-images/902f5/902f5d24e2b74f6b65ad9f9c2b0f2d3b433eba84" alt="Parent Lock Resource"
Overall, this locking feature is extremely useful for Portal to lock a resource, a resources group or even a subscription to prevent other users from accidentally deleting or modifying critical resources.
Hope this helps
Pingback: Dew Drop - February 13, 2018 (#2664) - Morning Dew
Pingback: Azure Weekly: Feb 19, 2018 – Build Azure