Solution:
This Powershell code will authenticate to Azure, connect to the proper Subscription and delete Blog file(s) based on the extension names .bak and .log. It will delete based on a user specified retention period.
In the code below, $RetentionPeriodInHours will hold the value set for number of hours. ex. "168" means delete all greater than 7 days old.
You will need your Microsoft Azure Subscription Name, Storage Account Name, Storage Account Access Key & Blog Container Name.
Powershell Code:
Login-AzureRmAccount
Set-AzureRmContext -SubscriptionName "<InsertAzureSubscriptionNameHere>"
$StorageAccount = "<InsertAzureStorageAccountNameHere>" $StorageAccountKey = "<InsertAzureStorageAccountAccessKeyAccessHere>" $StorageAccountContainer = "<InsertAzureStorageAccountBlogContainerNameHere>"
$Context = New-AzureStorageContext -StorageAccountName $StorageAccount -StorageAccountKey $StorageAccountKey
$RetentionPeriodInHours = [DateTime]::UtcNow.AddHours(-168) Get-AzureStorageBlob -Container $StorageAccountContainer -Context $Context | Where-Object {$_.LastModified.UtcDateTime -lt $RetentionPeriodInHours -and $_.BlobType -eq "PageBlob" -and $_.Name -like "*.bak"} | Remove-AzureStorageBlob
$RetentionPeriodInHours = [DateTime]::UtcNow.AddHours(-168) Get-AzureStorageBlob -Container $StorageAccountContainer -Context $Context | Where-Object {$_.LastModified.UtcDateTime -lt $RetentionPeriodInHours -and $_.BlobType -eq "PageBlob" -and $_.Name -like "*.log"} | Remove-AzureStorageBlob
If you have issues running the above Powershell code, you will likely need to download Azure Powershell Cmdlets. A quick method for this is to download Microsoft Web Platform Installer and then install Azure Powershell from it.
We placed the above Powershell Code inside a SQL Server Job and used that to purge SQL Backups > specified days.
Notes:
If you have any Blobs that have an active lease you will receive the below error in Powershell ISE:
data:image/s3,"s3://crabby-images/cf35b/cf35b9b96c863beb223952f366a37efd1d434ba5" alt=""
If you go to Azure Portal and try to delete that specific blob, it will show the error there also:
data:image/s3,"s3://crabby-images/fcd74/fcd74f9c478841996ef6dcb26d6df29ca821878a" alt=""
To fix this issue, you can download CloudXplorer. Once installed, add your Azure Storage Account, browse to the Blob Container & locate the Blob files that have the active lease and on each file select break lease.
data:image/s3,"s3://crabby-images/4c900/4c9006d3f140b9f5c727f6786a8daecae152870c" alt=""
Once the lease is broken, Powershell ISE will then be able to delete those blob files also.
That's it!
Resources:
Microsoft Azure
Get started with Azure PowerShell cmdlets
CloudXplorer
|
|
|
|
|