forked from harsha-simhadri/big-ann-benchmarks
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathinstall.py
78 lines (66 loc) · 2.44 KB
/
install.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
import json
import os
import argparse
import subprocess
from multiprocessing import Pool
def build(library, args, dockerfile):
print('Building %s...' % library)
if args is not None and len(args) != 0:
q = " ".join(["--build-arg " + x.replace(" ", "\\ ") for x in args])
else:
q = ""
try:
command = 'docker build %s --rm -t billion-scale-benchmark-%s -f' \
% (q, library )
command += ' install/Dockerfile.%s .' % (library) \
if not dockerfile else ' %s .' % dockerfile
subprocess.check_call(command, shell=True)
return {library: 'success'}
except subprocess.CalledProcessError:
return {library: 'fail'}
def build_multiprocess(args):
return build(*args)
if __name__ == "__main__":
parser = argparse.ArgumentParser(
formatter_class=argparse.ArgumentDefaultsHelpFormatter)
parser.add_argument(
"--proc",
default=1,
type=int,
help="the number of process to build docker images")
parser.add_argument(
'--algorithm',
metavar='NAME',
help='build only the named algorithm image',
default=None)
parser.add_argument(
'--dockerfile',
metavar='PATH',
help='build only the image from a Dockerfile path',
default=None)
parser.add_argument(
'--build-arg',
help='pass given args to all docker builds',
nargs="+")
args = parser.parse_args()
print('Building base image...')
subprocess.check_call(
'docker build \
--rm -t billion-scale-benchmark -f install/Dockerfile .', shell=True)
if args.dockerfile:
tags = [os.path.basename(os.path.dirname(args.dockerfile))]
elif args.algorithm:
tags = [args.algorithm]
elif os.getenv('LIBRARY'):
tags = [os.getenv('LIBRARY')]
else:
tags = [fn.split('.')[-1] for fn in os.listdir('install') if fn.startswith('Dockerfile.') and not 'faissgpu' in fn]
print('Building algorithm images... with (%d) processes' % args.proc)
if args.proc == 1:
install_status = [build(tag, args.build_arg, args.dockerfile) for tag in tags ]
else:
pool = Pool(processes=args.proc)
install_status = pool.map(build_multiprocess, [(tag, args.build_arg, args.dockerfile) for tag in tags ])
pool.close()
pool.join()
print('\n\nInstall Status:\n' + '\n'.join(str(algo) for algo in install_status))