-
Notifications
You must be signed in to change notification settings - Fork 130
/
Copy pathcount_hosts_by_tag.py
84 lines (77 loc) · 3.31 KB
/
count_hosts_by_tag.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
#!/usr/bin/env python
import re
import requests
# example usage:
#$ python count_hosts_by_tag.py -k <api_key> -a <app_key> windows
#Querying hosts with tag "windows"...
#2 windows
#
#$ python count_hosts_by_tag.py -k <api_key> -a <app_key> availability-zone
#Querying hosts with tag "availability-zone"...
#340 availability-zone:us-east-1a
#203 availability-zone:us-east-1c
#142 availability-zone:us-east-1d
#30 availability-zone:us-east-1b
#14 availability-zone:us-east-1e
#14 availability-zone:eastus
#13 availability-zone:europe-west1-b
#12 availability-zone:us-west-2b
#9 availability-zone:us-central1-b
#9 availability-zone:us-central1-a
#7 availability-zone:us-west-2c
def get_all_hosts(api_key, app_key):
params = {
"metrics": "avg:aws.ec2.cpuutilization,avg:azure.vm.percentage_cpu,avg:gcp.gce.instance.cpu.utilization,avg:system.cpu.idle,avg:system.cpu.iowait,avg:system.load.norm.15,avg:vsphere.cpu.usage",
"with_apps": "true",
"with_sources": "true",
"with_aliases": "true",
"with_meta": "true",
"with_mute_status": "true",
"with_tags": "true",
"api_key": api_key,
"application_key": app_key
}
response = requests.get(url="https://app.datadoghq.com/reports/v2/overview", params=params)
if response.ok:
return response.json()
def get_host_tag_counts(hosts, tag):
tag_pattern = re.compile(r"^%s[:.*]{0,1}" % tag)
host_count_by_tag = {}
# Query each host, building a count for each passed tag
for host in hosts["rows"]:
# Build unique list of tags from all sources
tags = set()
for src, src_tags in host["tags_by_source"].iteritems():
[tags.add(t) for t in filter(tag_pattern.match, src_tags)]
for t in tags:
if t not in host_count_by_tag:
host_count_by_tag[t] = 0
host_count_by_tag[t] += 1
return host_count_by_tag
if __name__ == "__main__":
import argparse
import os
import sys
parser = argparse.ArgumentParser(description="Count hosts in your infrastructure by a given tag")
parser.add_argument("-k", "--apikey", help="Your Datadog API key", type=str, default=None)
parser.add_argument("-a", "--appkey", help="Your Datadog app key", type=str, default=None)
parser.add_argument("tag", help="Tag used to count number of hosts", type=str)
args = parser.parse_args()
api_key = args.apikey or os.getenv("DATADOG_API_KEY", None)
app_key = args.appkey or os.getenv("DATADOG_APP_KEY", None)
errors = []
if not api_key:
errors.append("You must supply your Datadog API key by either passing a -k/--apikey argument or defining \
a DATADOG_API_KEY environment variable.")
if not app_key:
errors.append("You must supply your Datadog application key by either passing a -a/--appkey argument or defining \
a DATADOG_APP_KEY environment variable.")
if errors:
for error in errors:
print error
sys.exit(2)
print "Querying hosts with tag \"%s\"..." % args.tag
hosts = get_all_hosts(api_key, app_key)
host_tag_counts = get_host_tag_counts(hosts, args.tag)
for tag, host_count in sorted(host_tag_counts.iteritems(), key=lambda (k, v): (v, k), reverse=True):
print "%s \t %s" % (host_count, tag)