Create a new Resource group and then new Log Analytics Workspace
Export the Admin Diagnostics of the Resource group the server sits in to the Log Analytics Workspace you created
data:image/s3,"s3://crabby-images/0e997/0e997411d83ba140fab647a58e3418c38674701b" alt=""
data:image/s3,"s3://crabby-images/11fa1/11fa1b47313817c9ae2eb83ffab028a40546fa76" alt=""
Setup the Alert
data:image/s3,"s3://crabby-images/a501b/a501b46715eec977bc502a34a1cde9cbb8ab2e89" alt=""
Choose the Subscription
let DaysOfLogsToCheck = ago(7days);
let MaxUptime = ago(3d); // If the VM has been up for this long we want to know about it
AzureActivity
| where TimeGenerated > DaysOfLogsToCheck
// ActivityStatus == "Succeeded" makes more sense, but in practice it can be out of order, so "Started" is better in the real world
| where OperationName in ("Deallocate Virtual Machine", "Start Virtual Machine") and ActivityStatus == "Started"
// We need to keep only the most recent entry of type 'Deallocate Virtual Machine' or 'Start Virtual Machine'
| top 1 by TimeGenerated desc
// Check if the most recent entry was "Start Virtual Machine" and is older than MaxUpTime
| where OperationName == "Start Virtual Machine" and TimeGenerated <= MaxUptime
| project TimeGenerated, Resource, OperationName, ActivityStatus, ResourceId
data:image/s3,"s3://crabby-images/ee2c9/ee2c9413b30586eb2b5d77e2316f16611f44728c" alt=""