-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathdocker-compose.yml
178 lines (169 loc) · 5.16 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
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
version: '3.4'
# to run this you need to create a .env file with the contents of .env.example
services:
s3:
image: minio/minio:RELEASE.2024-03-30T09-41-56Z
# image: minio/minio:RELEASE.2020-12-18T03-27-42Z
container_name: s3
restart: always
hostname: s3
volumes:
- artifact-store:/data
ports:
- 9000:9000
- 9001:9001
environment:
MINIO_ROOT_USER: ${MINIO_ROOT_USER}
MINIO_ROOT_PASSWORD: ${MINIO_ROOT_PASSWORD}
networks:
- load-forecasting-net
command:
server /data --console-address ":9001"
healthcheck:
test: ["CMD", "curl", "-f", "http://localhost:9000/minio/health/live"]
interval: 10s
timeout: 10s
retries: 3
create_bucket:
# image: minio/mc:RELEASE.2019-07-17T22-13-42Z
image: minio/minio:RELEASE.2024-03-30T09-41-56Z
depends_on:
- s3
environment:
MINIO_ROOT_USER: ${MINIO_ROOT_USER}
MINIO_ROOT_PASSWORD: ${MINIO_ROOT_PASSWORD}
networks:
- load-forecasting-net
entrypoint: >
/bin/sh -c '
sleep 5;
/usr/bin/mc config host add s3 http://s3:9000 ${MINIO_ROOT_USER} ${MINIO_ROOT_PASSWORD} --api S3v4;
[[ ! -z "`/usr/bin/mc ls s3 | grep challenge`" ]] || /usr/bin/mc mb s3/${BUCKET_NAME};
/usr/bin/mc policy download s3/${BUCKET_NAME};
/usr/bin/mc policy set public s3/${BUCKET_NAME};
exit 0;
'
pgdb:
container_name: pgdb
hostname: pgdb
restart: always
image: inergy2020iccs/pgdb:16.2
volumes:
- database:/var/lib/postgresql/data
ports:
- 5432:5432
expose:
- '5432'
environment:
POSTGRES_USER: ${POSTGRES_USER}
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD}
POSTGRES_DATABASE: ${POSTGRES_DATABASE}
PGDATA: /var/lib/postgresql/data/pgdata
networks:
- load-forecasting-net
mlflow_server:
container_name: mlflow_server
hostname: mlflow_server
restart: always
image: inergy2020iccs/mlflow_server:2.11.3
ports:
- 5000:5000
expose:
- 5000
environment:
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD}
POSTGRES_USER: ${POSTGRES_USER}
POSTGRES_DATABASE: ${POSTGRES_DATABASE}
MLFLOW_S3_ENDPOINT_URL: http://s3:9000
AWS_ACCESS_KEY_ID: ${MINIO_ROOT_USER}
AWS_SECRET_ACCESS_KEY: ${MINIO_ROOT_PASSWORD}
depends_on:
- s3
- pgdb
networks:
- load-forecasting-net
command: bash -c
"mlflow server --backend-store-uri postgresql+psycopg2://${POSTGRES_USER}:${POSTGRES_PASSWORD}@pgdb:5432/${POSTGRES_DATABASE} --host 0.0.0.0 --default-artifact-root s3://${BUCKET_NAME}/"
backend:
hostname: deeptsf_backend
container_name: deeptsf_backend
# image: inergy2020iccs/deeptsf_backend:1.0.2 # only for releases
build: .
restart: always
ports:
- '8080:8080'
expose:
- '8080'
# volumes:
# - .:/app/. #debugging only
stdin_open: true
environment:
MLFLOW_TRACKING_URI: ${MLFLOW_TRACKING_URI}
MLFLOW_S3_ENDPOINT_URL: ${MLFLOW_S3_ENDPOINT_URL}
AWS_ACCESS_KEY_ID: ${MINIO_ROOT_USER}
AWS_SECRET_ACCESS_KEY: ${MINIO_ROOT_PASSWORD}
USE_KEYCLOAK: ${USE_KEYCLOAK}
GIT_PYTHON_REFRESH: ${GIT_PYTHON_REFRESH}
# deploy: # activate this if you want gpu usage
# resources:
# reservations:
# devices:
# - driver: nvidia
# capabilities: [gpu]
networks:
- load-forecasting-net
dagster:
container_name: deeptsf_dagster
hostname: deeptsf_dagster
# image: inergy2020iccs/deeptsf_dagster:1.0.1 # only for releases
build:
context: .
dockerfile: ./dagster-deeptsf/config/Dockerfile
environment:
MLFLOW_TRACKING_URI: ${MLFLOW_TRACKING_URI}
MLFLOW_S3_ENDPOINT_URL: ${MLFLOW_S3_ENDPOINT_URL}
AWS_ACCESS_KEY_ID: ${MINIO_ROOT_USER}
AWS_SECRET_ACCESS_KEY: ${MINIO_ROOT_PASSWORD}
# deploy: # activate this if you want gpu usage
# resources:
# reservations:
# devices:
# - driver: nvidia
# capabilities: [gpu]
expose:
- 8006
ports:
- 8006:8006
volumes:
- dagster-logs:/app/dagster-deeptsf
- ./uc2/user_datasets:/app/dagster-deeptsf/user_datasets
# - ./dagster-deeptsf/dagster_deeptsf:/app/dagster-deeptsf/dagster_deeptsf #debugging only
networks:
- load-forecasting-net
frontend:
container_name: deeptsf_dashboard
hostname: deeptsf_dashboard
image: inergy2020iccs/deeptsf_dashboard:1.0.2
# build: https://github.com/I-NERGY/deeptsf-dashboard.git
restart: always
expose:
- 3000
ports:
- 3000:3000
stdin_open: true
# environment:
## These environment variable cannot be set from within here. (React issues)
## Instead they should have been included as .env in the front end repo / image.
# DAGSTER_ENDPOINT_URL: ${DAGSTER_ENDPOINT_URL}
# REACT_APP_AUTH: "false"
# REACT_APP_MLFLOW: ${MLFLOW_TRACKING_URI}
# CHOKIDAR_USEPOLLING: "true"
# REACT_APP_NAME: Load_Forecasting_Dashboard
networks:
- load-forecasting-net
volumes:
database:
artifact-store:
dagster-logs:
networks:
load-forecasting-net: