This repository has been archived by the owner on Jan 27, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 93
/
docker-compose.yaml
131 lines (126 loc) · 3.31 KB
/
docker-compose.yaml
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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
# Copyright 2019 Intel Corporation
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
version: '3.5'
services:
avalon-shell:
container_name: avalon-shell
image: avalon-shell-dev
build:
context: .
dockerfile: ./docker/Dockerfile
args:
- XAUTHORITY=~/.Xauthority
- http_proxy
- https_proxy
- no_proxy
- IMAGE=$IMAGE
- DISTRO=$DISTRO
environment:
- DISPLAY
- http_proxy
- https_proxy
- no_proxy
volumes:
# Below volume mappings are required for DISPLAY settings by heart disease GUI client
- /tmp/.X11-unix:/tmp/.X11-unix
- ~/.Xauthority:/root/.Xauthority
command: |
bash -c "tail -f /dev/null"
stop_signal: SIGKILL
depends_on:
- avalon-enclave-manager
- avalon-listener
avalon-enclave-manager:
container_name: avalon-enclave-manager
image: avalon-enclave-manager-dev
build:
context: .
dockerfile: ./enclave_manager/Dockerfile
args:
- http_proxy
- https_proxy
- no_proxy
- ENCLAVE_TYPE=singleton
- DISTRO=$DISTRO
- IMAGE=$IMAGE
environment:
- http_proxy
- https_proxy
- no_proxy
expose:
# ZMQ socket port.
- 5555
volumes:
# Persistent volume to store sealed data across restarts
- ./.sealed:/project/avalon/.sealed
command: |
bash -c "
if [ $CLEAN_SEALED_DATA = 1 ]; then rm -f /project/avalon/.sealed/.sealed.data*; fi;
enclave_manager --lmdb_url http://avalon-lmdb:9090
tail -f /dev/null
"
depends_on:
- avalon-lmdb
avalon-lmdb:
container_name: avalon-lmdb
image: avalon-lmdb-dev
build:
context: .
dockerfile: ./shared_kv_storage/Dockerfile
args:
- http_proxy
- https_proxy
- no_proxy
- DISTRO=$DISTRO
- IMAGE=$IMAGE
environment:
- http_proxy
- https_proxy
- no_proxy
expose:
# Port is where lmdb server will listen for http request.
# Port should be same as in bind parameter or lmdb_config.toml
- 9090
command: |
bash -c "
kv_storage --bind http://avalon-lmdb:9090
tail -f /dev/null
"
avalon-listener:
container_name: avalon-listener
image: avalon-listener-dev
build:
context: .
dockerfile: ./listener/Dockerfile
args:
- http_proxy
- https_proxy
- no_proxy
- DISTRO=$DISTRO
- IMAGE=$IMAGE
environment:
- http_proxy
- https_proxy
- no_proxy
expose:
- 1947
# ZMQ socket port.
- 5555
command: |
bash -c "
avalon_listener --bind http://avalon-listener:1947 --lmdb_url http://avalon-lmdb:9090
tail -f /dev/null
"
depends_on:
- avalon-lmdb