Forum Discussion

kasunth's avatar
kasunth
Copper Contributor
Mar 15, 2021

I want see an alert when my disk space less than 5Gb in virtual machine.

I want see an alert when my disk space less than 5Gb in virtual machine. Please provide the steps that need to be configured. I want to get the email notification when my VM disk space less than 5GB.

 

 

7 Replies

  • Hello kasunth,

     

    Below is an instruction on how to create an alert based on custom log:

    1. Go to Alerts Panel and click on "Manage Actions".

    2. Create Action Group for your destination email address(here is a link with instruction about how to create action group: https://docs.microsoft.com/en-us/azure/azure-monitor/alerts/action-groups#create-the-action-group).

    3. Back to Alerts Panel and click "Mange alert rules".

    4. Click "New alert rule".

    5. As a Scope, select Log Analytics Workspace that contains logs related to Free Disk Space.

    6. In Condition area, click "Add condition", as signal type choose "Log" and then choose "Custom log search".

    7. Copy query below and past into "Search query" area:

    let PercentSpace = 10;
    Perf
    | where ObjectName == "LogicalDisk" and CounterName == "% Free Space"
    or ObjectName == "Logical Disk" and CounterName == "% Free Space"
    | where InstanceName != "D:"
    | summarize FreeSpace = avg(CounterValue) by Computer, InstanceName
    | where InstanceName contains ":" or InstanceName == "/"
    | where FreeSpace < PercentSpace

    8. Set alert logic as on screenshot below and click "Done":

    9.In Action area, add Action Group that you have created in step 2.

     

    10. Customize your alert like on example below:

    11. Click "Save".

    12. Enable your alert and that's all.

    • sparkislife's avatar
      sparkislife
      Copper Contributor

      oleksand_bakun 


      After migration to AMA, this query doesn't work for my dashboard anymore

      Perf
      | where TimeGenerated > ago(15minutes)
      | where ObjectName == "Logical Disk" or ObjectName == "LogicalDisk"
      | where CounterName == "% Free Space"
      | where InstanceName <> "_Total" and InstanceName !contains "HarddiskVolume"
      | summarize AggregatedValue = avg(CounterValue) by Computer, InstanceName
      | where AggregatedValue <= 22
      //| top 10 by AggregatedValue
      | order by AggregatedValue asc

       

      any clue(s)?

      Do i need to add anything to my perf count on DCR or diag the vms

      • Eric_Keown's avatar
        Eric_Keown
        Copper Contributor
        The AMA writes to the insightmetrics or at least mine is.
        This is what my query looks like for disk space
        let availpercent = 10;
        InsightsMetrics
        | where Origin == "vm.azm.ms"
        and Namespace == "LogicalDisk" and Name == "FreeSpacePercentage"
        | extend Disk=tostring(todynamic(Tags)["vm.azm.ms/mountId"])
        | summarize Disk_Free_Space = avg(Val) by Computer, Disk, _ResourceId
        | project Computer, Disk, Disk_Free_Space
        | where Disk_Free_Space < availpercent

        You might want to try that.

Resources