library
turbot/azure_thrifty
- Detect & correct App Service Plans if unused
- Detect & correct Compute disks attached to stopped VMs
- Detect & correct Compute unattached disks
- Detect & correct Compute disks with high IOPS
- Detect & correct Compute disks with low usage
- Detect & correct Compute snapshots exceeding max age
- Detect & correct Compute snapshots with premium storage
- Detect & correct Compute virtual machines
- Detect & correct Compute virtual machine with low utilization
- Detect & correct Compute disks exceeding max size
- Detect & correct HDInsight clusters exceeding max age
- Detect & correct Kubernetes clusters exceeding max age
- Detect & correct Kusto clusters exceeding max age
- Detect & correct Kusto clusters without autoscaling
- Detect & correct Monitor log profiles without retention policy
- Detect & correct Network application gateways without autoscaling
- Detect & correct Network load balancers if unused
- Detect & correct Network NAT gateways if unused
- Detect & correct Network unattached public IPs
- Detect & correct Network virtual network gateways if unused
- Detect & correct Service Fabric clusters exceeding max age
- Detect & correct SQL databases exceeding max age
- Detect & correct Storage accounts without lifecycle policy
- Detect & correct Compute virtual machine scale sets if unused
Get Involved
Version
Detect & correct AppService plans if unused
Overview
Azure AppService plans with no app attached still cost money and should be deleted.
This pipeline allows you to specify a collection of AppService plans with no app attached and either sends notifications or attempts to perform predefined corrective actions upon the collection.
Getting Started
By default, this trigger is disabled, however it can be configured by setting the below variables
app_service_plans_if_unused_trigger_enabled
should be set totrue
as the default isfalse
.app_service_plans_if_unused_trigger_schedule
should be set to your desired running scheduleapp_service_plans_if_unused_default_action
should be set to your desired action (i.e."notify"
for notifications or"delete_app_service_plan"
to delete app service plan).
Then starting the server:
flowpipe server
or if you've set the variables in a .fpvars
file:
flowpipe server --var-file=/path/to/your.fpvars
Query
select concat( asp.id, ' [', asp.resource_group, '/', asp.subscription_id, ']' ) as title, asp.id as id, asp.name, asp.resource_group, asp.subscription_id, asp._ctx ->> 'connection_name' as credfrom azure_app_service_plan as asp left join azure_subscription as sub on sub.subscription_id = asp.subscription_idwhere apps is null and sku_tier <> 'Free';
Schedule
15m