-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdocker.py
executable file
·59 lines (43 loc) · 1.96 KB
/
docker.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
import argparse
import json
import os
parser = argparse.ArgumentParser()
parser.add_argument('-c', type=str, help='Path to config file')
parser.add_argument('-t', type=str, help='Thread count')
parser.add_argument('-o', type=str, help='Output directory')
parser.add_argument('-m', type=int, default=10, help='Memory limit in GB, default: 10')
parser.add_argument('-i', type=str,
help='[Optional] Docker image, only for development purposes')
args = parser.parse_args()
def process_configs(configs: dict) -> dict:
mounts = {}
for key, value in configs.items():
if isinstance(value, dict):
mounts.update(process_configs(value))
else:
if isinstance(value, str) and os.path.exists(value):
extension = os.path.splitext(value)[1]
inside_path = f"/srv/input/{key}{extension}"
mounts[inside_path] = os.path.abspath(value)
configs[key] = inside_path
return mounts
image = args.i if args.i else "nicotru/tf-prioritizer:master"
config_path = os.path.abspath(args.c)
threads = args.t
output = os.path.abspath(args.o)
memory = args.m
os.makedirs(output, exist_ok=True)
with open(config_path, 'r') as f:
configs = json.load(f)
mounts = process_configs(configs)
docker_config_file = os.path.join(os.path.dirname(output), 'docker_config.json')
with open(docker_config_file, 'w') as f:
json.dump(configs, f, indent=4)
volume_string = ' '.join([f'-v {v}:{k}:ro' for k, v in mounts.items()])
internal_command = f"java -Xmx{memory}g -jar /srv/TF-Prioritizer.jar -t {threads} -o /srv/wd -c /srv/input/configs.json"
external_command = f"docker run --cpus='{threads}' --user='{os.getuid()}':'{os.getgid()}'" \
f" -v '{docker_config_file}:/srv/input/configs.json:ro' {volume_string} -v '{output}:/srv/wd:rw,Z' " \
f"{image} {internal_command}"
if not args.i:
os.system("docker image pull " + image)
os.system(external_command)