Merge branch '2800-python-global-state' into 2800-pgs
[arvados.git] / docker / build_tools / Makefile
1 # This is the 'shell hack'. Call make with DUMP=1 to see the effect.
2 ifdef DUMP
3 OLD_SHELL := $(SHELL)
4 SHELL = $(warning [$@])$(OLD_SHELL) -x
5 endif
6
7 all: skydns-image skydock-image api-image compute-image doc-image workbench-image keep-image sso-image shell-image
8
9 IMAGE_FILES := $(shell ls *-image 2>/dev/null |grep -v -E 'debian-arvados-image|skydns-image|skydock-image')
10 GENERATED_FILES := $(shell ls */generated/* 2>/dev/null)
11 GENERATED_DIRS := $(shell ls */generated 2>/dev/null)
12
13 # `make clean' removes the files generated in the build directory
14 # but does not remove any docker images generated in previous builds
15 clean:
16         @echo "make clean"
17         -@rm -rf build
18         +@[ "$(IMAGE_FILES)$(GENERATED_FILES)" = "" ] || rm $(IMAGE_FILES) $(GENERATED_FILES) 2>/dev/null
19         +@[ "$(GENERATED_DIRS)" = "" ] || rmdir */generated 2>/dev/null
20
21 DEBIAN_IMAGE := $(shell $(DOCKER) images -q arvados/debian |head -n1)
22
23 REALCLEAN_CONTAINERS := $(shell $(DOCKER) ps -a |grep -e arvados -e api_server -e keep_server -e doc_server -e workbench_server |cut -f 1 -d' ')
24 REALCLEAN_IMAGES := $(shell $(DOCKER) images -q arvados/* |grep -v $(DEBIAN_IMAGE) 2>/dev/null)
25 DEEPCLEAN_IMAGES := $(shell $(DOCKER) images -q arvados/*)
26 SKYDNS_CONTAINERS := $(shell $(DOCKER) ps -a |grep -e crosbymichael/skydns -e crosbymichael/skydock |cut -f 1 -d' ')
27 SKYDNS_IMAGES := $(shell $(DOCKER) images -q crosbymichael/skyd*)
28
29 # `make realclean' will also remove the Arvados docker images (but not the
30 # arvados/debian image) and force subsequent makes to build the entire chain
31 # from the ground up
32 realclean: clean
33         @echo "make realclean"
34         +@[ "`$(DOCKER) ps -q`" = '' ] || $(DOCKER) stop `$(DOCKER) ps -q`
35         +@[ "$(REALCLEAN_CONTAINERS)" = '' ] || $(DOCKER) rm $(REALCLEAN_CONTAINERS)
36         +@[ "$(REALCLEAN_IMAGES)" = '' ] || $(DOCKER) rmi $(REALCLEAN_IMAGES)
37
38 # `make deepclean' will remove all Arvados docker images and the skydns/skydock
39 # images and force subsequent makes to build the entire chain from the ground up
40 deepclean: clean
41         @echo "make deepclean"
42         -@rm -f debian-arvados-image 2>/dev/null
43         -@rm -f skydns-image skydock-image 2>/dev/null
44         +@[ "`$(DOCKER) ps -q`" = '' ] || $(DOCKER) stop `$(DOCKER) ps -q`
45         +@[ "$(REALCLEAN_CONTAINERS)" = '' ] || $(DOCKER) rm $(REALCLEAN_CONTAINERS)
46         +@[ "$(DEEPCLEAN_IMAGES)" = '' ] || $(DOCKER) rmi $(DEEPCLEAN_IMAGES)
47         +@[ "$(SKYDNS_CONTAINERS)" = '' ] || $(DOCKER) rm $(SKYDNS_CONTAINERS)
48         +@[ "$(SKYDNS_IMAGES)" = '' ] || $(DOCKER) rmi $(SKYDNS_IMAGES)
49
50 # ============================================================
51 # Dependencies for */generated files which are prerequisites
52 # for building docker images.
53
54 CONFIG_RB = build_tools/config.rb
55
56 BUILD = build/.buildstamp
57
58 BASE_DEPS = base/Dockerfile config.yml $(BASE_GENERATED)
59
60 SLURM_DEPS = slurm/Dockerfile config.yml $(SLURM_GENERATED)
61
62 JOBS_DEPS = jobs/Dockerfile
63
64 JAVA_BWA_SAMTOOLS_DEPS = java-bwa-samtools/Dockerfile
65
66 API_DEPS = api/* config.yml $(API_GENERATED)
67
68 SHELL_DEPS = shell/* config.yml $(SHELL_GENERATED)
69
70 COMPUTE_DEPS = compute/* config.yml $(COMPUTE_GENERATED)
71
72 DOC_DEPS = doc/Dockerfile doc/apache2_vhost
73
74 WORKBENCH_DEPS = workbench/Dockerfile \
75                  config.yml \
76                  $(WORKBENCH_GENERATED)
77
78 KEEP_DEPS = keep/Dockerfile config.yml $(KEEP_GENERATED)
79
80 SSO_DEPS = config.yml $(SSO_GENERATED)
81
82 BCBIO_NEXTGEN_DEPS = bcbio-nextgen/Dockerfile
83
84 BASE_GENERATED = base/generated/arvados.tar.gz
85
86 COMPUTE_GENERATED_IN   = compute/*.in
87 COMPUTE_GENERATED      = compute/generated/*
88
89 KEEP_GENERATED_IN      = keep/*.in
90 KEEP_GENERATED         = keep/generated/*
91
92 API_GENERATED_IN       = api/*.in
93 API_GENERATED          = api/generated/*
94
95 SHELL_GENERATED_IN     = shell/*.in
96 SHELL_GENERATED        = shell/generated/*
97
98 SLURM_GENERATED_IN     = slurm/*.in
99 SLURM_GENERATED        = slurm/generated/*
100
101 WORKBENCH_GENERATED_IN = workbench/*.in
102 WORKBENCH_GENERATED    = workbench/generated/*
103
104 SSO_GENERATED_IN       = sso/*.in
105 SSO_GENERATED          = sso/generated/*
106
107 KEEP_DEPS += keep/generated/bin/keepproxy
108 KEEP_DEPS += keep/generated/bin/keepstore
109 keep/generated/bin/%: $(wildcard build/services/%/*.go)
110         mkdir -p keep/generated/src/git.curoverse.com
111         ln -sfn ../../../../.. keep/generated/src/git.curoverse.com/arvados.git
112         GOPATH=$(shell pwd)/keep/generated go get $(@:keep/generated/bin/%=git.curoverse.com/arvados.git/services/%)
113
114 $(BUILD):
115         mkdir -p build
116         rsync -rlp --exclude=docker/ --exclude='**/log/*' --exclude='**/tmp/*' \
117                 --chmod=Da+rx,Fa+rX ../ build/
118         find build/ -name \*.gem -delete
119         cd build/services/fuse/ && python setup.py build
120         cd build/sdk/python/ && python setup.py build
121         cd build/sdk/cli && gem build arvados-cli.gemspec
122         cd build/sdk/ruby && gem build arvados.gemspec
123         touch build/.buildstamp
124
125 $(SLURM_GENERATED): $(BUILD)
126         $(CONFIG_RB) slurm
127         mkdir -p slurm/generated
128
129 $(BASE_GENERATED): $(BUILD)
130         $(CONFIG_RB) base
131         mkdir -p base/generated
132         tar -czf base/generated/arvados.tar.gz -C build .
133
134 $(API_GENERATED): $(API_GENERATED_IN)
135         $(CONFIG_RB) api
136
137 $(SHELL_GENERATED): $(SHELL_GENERATED_IN)
138         $(CONFIG_RB) shell
139
140 $(WORKBENCH_GENERATED): $(WORKBENCH_GENERATED_IN)
141         $(CONFIG_RB) workbench
142
143 $(COMPUTE_GENERATED): $(COMPUTE_GENERATED_IN)
144         $(CONFIG_RB) compute
145
146 $(SSO_GENERATED): $(SSO_GENERATED_IN)
147         $(CONFIG_RB) sso
148
149 $(KEEP_GENERATED): $(KEEP_GENERATED_IN)
150         $(CONFIG_RB) keep
151
152 # The docker build -q option suppresses verbose build output.
153 # Necessary to prevent failure on building warehouse; see
154 # https://github.com/dotcloud/docker/issues/3172
155 DOCKER_BUILD = $(DOCKER) build -q --rm=true
156
157 # ============================================================
158 # The main Arvados servers: api, doc, workbench, compute
159
160 api-image: passenger-image $(BUILD) $(API_DEPS)
161         @echo "Building api-image"
162         mkdir -p api/generated
163         tar -czf api/generated/api.tar.gz -C build/services api
164         $(DOCKER_BUILD) -t arvados/api api
165         date >api-image
166
167 shell-image: base-image $(BUILD) $(SHELL_DEPS)
168         @echo "Building shell-image"
169         mkdir -p shell/generated
170         $(DOCKER_BUILD) -t arvados/shell shell
171         date >shell-image
172
173 compute-image: slurm-image $(BUILD) $(COMPUTE_DEPS)
174         @echo "Building compute-image"
175         $(DOCKER_BUILD) -t arvados/compute compute
176         date >compute-image
177
178 doc-image: base-image $(BUILD) $(DOC_DEPS)
179         @echo "Building doc-image"
180         mkdir -p doc/generated
181         tar -czf doc/generated/doc.tar.gz -C build doc
182         $(DOCKER_BUILD) -t arvados/doc doc
183         date >doc-image
184
185 keep-image: debian-arvados-image $(BUILD) $(KEEP_DEPS)
186         @echo "Building keep-image"
187         $(DOCKER_BUILD) -t arvados/keep keep
188         date >keep-image
189
190 jobs-image: base-image $(BUILD) $(JOBS_DEPS)
191         $(DOCKER_BUILD) -t arvados/jobs jobs
192         date >jobs-image
193
194 java-bwa-samtools-image: jobs-image $(BUILD) $(JAVA_BWA_SAMTOOLS_DEPS)
195         $(DOCKER_BUILD) -t arvados/jobs-java-bwa-samtools java-bwa-samtools
196         date >java-bwa-samtools-image
197
198 bcbio-nextgen-image: $(BUILD) $(BASE_GENERATED) $(BCBIO_NEXTGEN_DEPS)
199         rm -rf bcbio-nextgen/generated
200         cp -r base/generated bcbio-nextgen
201         $(DOCKER_BUILD) -t arvados/bcbio-nextgen bcbio-nextgen
202         date >bcbio-nextgen-image
203
204 workbench-image: passenger-image $(BUILD) $(WORKBENCH_DEPS)
205         @echo "Building workbench-image"
206         mkdir -p workbench/generated
207         tar -czf workbench/generated/workbench.tar.gz -C build/apps workbench
208         $(DOCKER_BUILD) -t arvados/workbench workbench
209         date >workbench-image
210
211 sso-image: passenger-image $(SSO_DEPS)
212         @echo "Building sso-image"
213         $(DOCKER_BUILD) -t arvados/sso sso
214         date >sso-image
215
216 # ============================================================
217 # The arvados/base image is the base Debian image plus packages
218 # that are dependencies for every Arvados service.
219
220 passenger-image: base-image
221         @echo "Building passenger-image"
222         $(DOCKER_BUILD) -t arvados/passenger passenger
223         date >passenger-image
224
225 slurm-image: base-image $(SLURM_DEPS)
226         @echo "Building slurm-image"
227         $(DOCKER_BUILD) -t arvados/slurm slurm
228         date >slurm-image
229
230 base-image: debian-arvados-image $(BASE_DEPS)
231         @echo "Building base-image"
232         $(DOCKER_BUILD) -t arvados/base base
233         date >base-image
234
235 debian-arvados-image:
236         @echo "Building debian-arvados-image"
237         ./mkimage-debootstrap.sh arvados/debian wheezy ftp://ftp.us.debian.org/debian/
238         date >debian-arvados-image
239
240 skydns-image:
241         @echo "Downloading skydns-image"
242         $(DOCKER) pull crosbymichael/skydns
243         date >skydns-image
244
245 skydock-image:
246         @echo "Downloading skydock-image"
247         $(DOCKER) pull crosbymichael/skydock
248         date >skydock-image