top of page
Search
Writer's pictureShannon

Exploratory FinOps Scripts: Azure Disk and Snapshot Information

In my presales role at AHEAD, I focus on the "art of the possible" in customer conversations. We often analyze customers' cloud storage footprints during a FinOps campaign, noting that "lift and shift" usually places on-premises servers on premium storage, regardless of environment. Additionally, customers often lose track of aging snapshots and lack insight into their overall costs.


I developed a quick PowerShell exploratory script for Azure to help make informed decisions very quickly! As I usually outline, these may not feel super sophisticated to gurus in this space. Know I mostly build scripts or queries to grab information quickly (time is of the essence in my role). If you're a PoSH guru, feel free to take these as "starter" scripts/queries and expand to your heart's content! If you do get really sophisticated and savvy, please share what you come up with!


Let's outline the ask, first and foremost. I had a customer who needed to determine what Managed Disks were deployed, the type, the size, what VM they were attached to, and if the disks had aging snapshots. In theory that should be straightforward, right? Wrong. Due to the way this information is captured via the ARM API endpoints, I had iterate through each subscription using a few different PowerShell cmdlets from the Az module: Get-AzVM, Get-AzDisk, and Get-AzSnapshot. Given how helpful this proved, I wanted to share this here in case you are ever tasked with a similar ask and feel confident or comfortable with PowerShell. Note, you can also take a peek at my code on GitHub as well: AzAndPoSHOperations/PoSH/getDiskandSnapshotInfo.ps1 at master · sbkuehn/AzAndPoSHOperations

# Connect to Azure
Connect-AzAccount

# Define the path for the CSV file
$path = Read-Host -Prompt "Please Provide a file path."

# Initialize an array to store combined VM, disk, and snapshot details
$details = @()

# Get all subscriptions in the Azure tenant
$subscriptions = Get-AzSubscription

# Loop through each subscription
foreach ($subscription in $subscriptions) {
  # Select the subscription
  Select-AzSubscription -SubscriptionId $subscription.Id

  # Get all VMs in the subscription
  $vms = Get-AzVM

  # Loop through each VM
  foreach ($vm in $vms) {
     $vmName = $vm.Name
     $resourceGroup = $vm.ResourceGroupName

  # Get all managed disks attached to the VM
  $disks = Get-AzDisk -ResourceGroupName $resourceGroup | Where-Object ` {$_.ManagedBy -eq $vm.Id}
     foreach ($disk in $disks) {
       # Add disk details to the array
       $details += [PSCustomObject]@{
           Type = "Disk"
           VMName = $vmName
           Name = $disk.Name
           ManagedBy = $disk.ManagedBy
           SKU = $disk.Sku.Name
           Size = $disk.DiskSizeGB
           Id = $disk.UniqueId
           ResourceGroup = $disk.ResourceGroupName
           SubscriptionName = $subscription.Name
           SubscriptionId = $subscription.Id
           CreationDate = $null
           SourceId = $null
         }
     }
     # Get all snapshots in the subscription
     $snapshots = Get-AzSnapshot -ResourceGroupName $resourceGroup

     # Loop through each snapshot
     foreach ($snapshot in $snapshots) {

       # Add snapshot details to the array
       $details += [PSCustomObject]@{
           Type = "Snapshot"
           VMName = $vmName
           Name = $snapshot.Name
           ManagedBy = $null
           SKU = $null
           Size = $null
           Id = $snapshot.Id
           ResourceGroup = $snapshot.ResourceGroupName
           SubscriptionName = $subscription.Name
           SubscriptionId = $subscription.Id
           CreationDate = $snapshot.TimeCreated
           SourceId = $snapshot.CreationData.SourceResourceId
         }
     }
  }
}

# Output combined details to CSV file
$details | Export-Csv -Path $path -NoTypeInformation
Write-Output "CSV file with combined VM, disk, and snapshot details has been created at $path."

Happy PowerShellin' out there! Feel free to comment on the post or drop me a line on how you may have taken this script and added more to suit your needs. I always find that 1) insightful and 2) something worthy of exploring or sharing further myself!


Cheers!

Recent Posts

See All

© 2020 Shannon B. Kuehn

  • LinkedIn
  • Twitter
bottom of page