-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdocker-compose.yml
More file actions
120 lines (118 loc) · 3.11 KB
/
docker-compose.yml
File metadata and controls
120 lines (118 loc) · 3.11 KB
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
services:
consul-server-1:
image: "hashicorp/consul:latest"
container_name: consul-server-1
hostname: consul-server-1
command: "agent -server -bootstrap-expect=3 -node=consul-server-1 -config-dir=/consul/config"
volumes:
- ./build/consul/server1_config.json:/consul/config/config.json
ports:
- "8500:8500"
- "53:53"
networks:
- helios-net
consul-server-2:
image: "hashicorp/consul:latest"
container_name: consul-server-2
hostname: consul-server-2
command: "agent -server -bootstrap-expect=3 -node=consul-server-2 -config-dir=/consul/config"
volumes:
- ./build/consul/server2_config.json:/consul/config/config.json
networks:
- helios-net
consul-server-3:
image: "hashicorp/consul:latest"
container_name: consul-server-3
hostname: consul-server-3
command: "agent -server -bootstrap-expect=3 -node=consul-server-3 -config-dir=/consul/config"
volumes:
- ./build/consul/server3_config.json:/consul/config/config.json
networks:
- helios-net
consul-client:
image: "hashicorp/consul:latest"
container_name: consul-client
hostname: consul-client
command: >
agent -node=consul-client -config-dir=/consul/config
-retry-join=consul-server-1
-retry-join=consul-server-2
-retry-join=consul-server-3
volumes:
- ./build/consul/client_config.json:/consul/config/config.json
depends_on:
- consul-server-1
- consul-server-2
- consul-server-3
networks:
- helios-net
helios-leader-1:
build:
context: .
dockerfile: build/docker/leader.Dockerfile
container_name: helios-leader-1
hostname: helios-1
environment:
- CONSUL_HTTP_ADDR=consul-server-1:8500
- NODE_ID=1
- RAFT_DIR=/raft
- HELIOS_HOST=helios-1
- HELIOS_PORT=6330
depends_on:
- consul-server-1
- consul-server-2
- consul-server-3
networks:
- helios-net
ports:
- "6330:6330"
helios-leader-2:
build:
context: .
dockerfile: build/docker/leader.Dockerfile
container_name: helios-leader-2
hostname: helios-2
environment:
- CONSUL_HTTP_ADDR=consul-server-1:8500
- NODE_ID=2
- RAFT_DIR=/raft
- HELIOS_HOST=helios-2
- HELIOS_PORT=6330
depends_on:
- helios-leader-1
networks:
- helios-net
ports:
- "6331:6330"
helios-leader-3:
build:
context: .
dockerfile: build/docker/leader.Dockerfile
container_name: helios-leader-3
hostname: helios-3
environment:
- CONSUL_HTTP_ADDR=consul-server-1:8500
- NODE_ID=3
- RAFT_DIR=/raft
- HELIOS_HOST=helios-3
- HELIOS_PORT=6330
depends_on:
- helios-leader-1
networks:
- helios-net
ports:
- "6332:6330"
# helios-worker:
# build:
# dockerfile: worker.Dockerfile
# container_name: helios-worker
# hostname: helios-worker
# environment:
# - CONSUL_HTTP_ADDR=consul-server-1:8500
# depends_on:
# - consul-server-1
# networks:
# - helios-net
networks:
helios-net:
driver: bridge