-
Notifications
You must be signed in to change notification settings - Fork 145
/
Copy pathgenconfig.py
executable file
·77 lines (69 loc) · 3.15 KB
/
genconfig.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
#!/usr/bin/env python3
import argparse
import os
import yaml
import re
import sys
def gen_targets(servers, cluster):
if ':' not in servers:
raise Exception('Server list must contain a dc name')
dcs = servers.split(':', maxsplit=1)
res = {"labels": {"cluster": cluster, "dc": dcs[0]}}
res["targets"] = dcs[1].split(',')
return res
def get_servers_from_nodetool_status():
res = []
dc = None
ips = []
for line in sys.stdin:
if dc:
ip = re.search(r".. ([\d\.]+)\s", line)
if ip:
ips.append(ip.group(1))
m = re.search(r"Datacenter: ([^\s]+)\s*$", line)
if m:
if dc:
res.append(dc + ":" + ",".join(ips))
ips = []
dc = m.group(1)
if dc:
res.append(dc + ":" + ",".join(ips))
return res
def dump_yaml_no_dc(directory, filename, servers):
try:
os.mkdir(directory)
except OSError as err:
if err.errno != 17:
raise
pass
with open(os.path.join(directory, filename), 'w') as stream:
yaml.dump([{"targets": servers}], stream, default_flow_style=False)
def dump_yaml(directory, filename, servers, cluster):
try:
os.mkdir(directory)
except OSError as err:
if err.errno != 17:
raise
pass
with open(os.path.join(directory, filename), 'w') as yml_file:
yaml.dump([gen_targets(s, cluster) for s in servers], yml_file, default_flow_style=False)
if __name__ == "__main__":
parser = argparse.ArgumentParser(description="Generate configuration for prometheus")
parser.add_argument('-d', '--directory', help="directory where to generate the configuration files", type=str, default="./")
parser.add_argument('-s', '--scylla', help="Deprecated: Generate scylla_servers.yml file", action='store_true')
parser.add_argument('-n', '--node', help="Deprecated: Generate node_exporter_servers.yml file", action='store_true')
parser.add_argument('-c', '--cluster', help="The cluster name", type=str, default="my-cluster")
parser.add_argument('-o', '--output-file', help="The servers output file", type=str, default="scylla_servers.yml")
parser.add_argument('-NS', '--nodetool-status', help="Use nodetool status output. Output is read from stdin", action='store_true')
parser.add_argument('servers', help="list of nodes to configure, separated by space", nargs='*', type=str, metavar='node_ip')
parser.add_argument('-dc', '--datacenters', action='append', help="list of dc and nodes to configure separated by space. Each dc/node entry is a combination of {dc}:ip1,ip2..ipn")
arguments = parser.parse_args()
if arguments.nodetool_status:
dump_yaml(arguments.directory, arguments.output_file, get_servers_from_nodetool_status(), arguments.cluster)
else:
if arguments.servers:
dump_yaml_no_dc(arguments.directory, arguments.output_file, arguments.servers)
else:
dump_yaml(arguments.directory, arguments.output_file, arguments.datacenters , arguments.cluster)
if arguments.node:
dump_yaml_no_dc(arguments.directory, 'node_exporter_servers.yml', arguments.servers)