forked from CS3219-AY2425S1/cs3219-ay2425s1-project-g06
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdocker-compose.yml
159 lines (148 loc) · 3.82 KB
/
docker-compose.yml
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
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
services:
question:
image: echomo/cs3219-question:test1
ports:
- "3002:3002"
restart: always
environment:
- DB_CLOUD_URI=<> # add your own DB_CLOUD_URI
- PORT=3002
- ENV=PROD
- CODE_EXECUTION_SERVICE_URL=http://code-execution-server:7002
user:
image: echomo/cs3219-user:test0
ports:
- "3001:3001"
restart: always
environment:
- DB_CLOUD_URI=<> # add your own DB_CLOUD_URI
- PORT=3001
- ENV=PROD
- JWT_SECRET=secret
code-execution-rabbitmq:
image: rabbitmq:4.0-management
ports:
- "7004:5672"
healthcheck:
test: ["CMD", "rabbitmqctl", "status"]
interval: 10s
timeout: 5s
retries: 5
code-execution-redis:
image: redis:alpine
ports:
- "7001:6379"
healthcheck:
test: ["CMD", "redis-cli", "ping"]
interval: 10s
timeout: 5s
retries: 5
code-execution-server:
image: echomo/cs3219-code-exec-server:test0
ports:
- "7002:7002"
restart: always
depends_on:
code-execution-rabbitmq:
condition: service_healthy
code-execution-redis:
condition: service_healthy
environment:
- RABBITMQ_PORT=5672
- RABBITMQ_HOST=code-execution-rabbitmq
- REDIS_HOST=code-execution-redis
- REDIS_PORT=6379
- USER_SERVICE_URL=http://user:3001
code-execution-worker:
image: echomo/cs3219-code-exec-worker:test0
pids_limit: 60
cpus: 1
mem_limit: 150M
restart: on-failure
depends_on:
code-execution-rabbitmq:
condition: service_healthy
code-execution-redis:
condition: service_healthy
environment:
- RABBITMQ_PORT=5672
- RABBITMQ_HOST=code-execution-rabbitmq
- REDIS_HOST=code-execution-redis
- REDIS_PORT=6379
- COMPILE_SHELL=False
deploy:
replicas: 1
restart_policy:
condition: any
delay: 3s
window: 5s
rabbitmq:
image: dedsecrattle/rabbitmq-delayed-exchange
restart: always
ports:
- "5672:5672" # RabbitMQ message broker
- "15672:15672" # RabbitMQ management plugin
healthcheck:
test: ["CMD", "rabbitmqctl", "status"]
interval: 10s
timeout: 5s
retries: 5
communication:
image: echomo/cs3219-communication:test0
ports:
- "3004:3004"
- "9000:9000"
restart: always
environment:
- PORT=3004
- PEERJS_PORT=9000
matching:
image: echomo/cs3219-matching:test1
depends_on:
rabbitmq:
condition: service_healthy
restart: always
ports:
- "3003:3003"
environment:
- QUESTION_SERVICE=http://question:3002
- PORT=3003
- RABBITMQ_URL=amqp://rabbitmq:5672
collaboration:
image: echomo/cs3219-collaboration:test1
ports:
- "3005:3005"
restart: always
environment:
- LOG_LEVEL=20
- USER_SERVICE_URL=http://user:3001
- MATCHING_SERVICE_URL=http://matching:3003
ai-hint-service:
image: echomo/cs3219-ai-hint:test0
ports:
- "3006:8000"
depends_on:
- question
environment:
- OPENAI_API_KEY=sk-proj-<> # Add your own OpenAI API key
- QUESTION_SERVICE_URL=http://question:3002
frontend:
image: echomo/cs3219-frontend:test5
environment:
- REACT_APP_USER_SERVICE_URL=http://localhost:3001/
- REACT_APP_QUESTION_SERVICE_URL=http://localhost:3002/
- REACT_APP_MATCHING_SERVICE_URL=http://localhost:3003
- REACT_APP_COMMUNICATION_SERVICE_URL=http://localhost:3004
- REACT_APP_COLLABORATION_SERVICE_URL=http://localhost:3005
- REACT_APP_AI_HINT_URL=http://localhost:3006
- REACT_APP_VIDEO_SERVICE_PORT=9000
ports:
- "80:80"
restart: always
depends_on:
- user
- matching
- question
- collaboration
- rabbitmq
- ai-hint-service