forked from Submitty/Submitty
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathgenerate_workers.py
70 lines (53 loc) · 2.29 KB
/
generate_workers.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
#!/usr/bin/python3
import argparse
import glob
import ipaddress
import json
import os
from collections import OrderedDict
from typing import Union, cast
def get_args():
parser = argparse.ArgumentParser(
description='Script to generate configuration for '
'development worker machines')
parser.add_argument('-n', '--num', default=1, type=int,
help='Number of worker machines to configure')
parser.add_argument('--ip-range', default='192.168.56.0/24', type=ipaddress.ip_network,
help='IP address range for workers')
parser.add_argument('--base-port', default=2240, type=int,
help='Base ssh port (ports will be assigned incrementally)')
return parser.parse_args()
def main():
args = get_args()
workers = OrderedDict()
rootdir = os.path.dirname(os.path.realpath(__file__))
workerfile = os.path.join(rootdir, '.vagrant', 'workers.json')
if len(glob.glob(os.path.join(rootdir, '.vagrant', 'machines', '*', '*', 'action_provision'))):
if input("Warning: There are existing vagrant machines in this project that may conflict"
" with new configuration. Are you sure you would like to proceed? [y/N] "
)[0].lower() != 'y':
return
if os.path.isfile(workerfile):
if input('Overwrite existing worker configuration? [y/N] ')[0].lower() != 'y':
return
ips = cast(Union[ipaddress.IPv4Network, ipaddress.IPv6Network], args.ip_range).hosts()
if isinstance(ips, list):
ips = iter(ips)
for i in range(1, args.num+1):
ip = next(ips, None)
while (ip is not None
and (ip.is_reserved or isinstance(ip, ipaddress.IPv4Address)
and str(ip).endswith('.1'))):
ip = next(ips, None)
if ip is None:
raise IndexError("IP range insufficient for requested number of workers")
data = OrderedDict()
data['ip_addr'] = str(ip)
data['ssh_port'] = args.base_port + i
workers[f'worker-{i}'] = data
os.makedirs(os.path.dirname(workerfile), exist_ok=True)
with open(workerfile, 'w') as file:
json.dump(workers, file, indent=4)
print('Wrote new configuration to ' + workerfile)
if __name__ == '__main__':
main()