-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathprod-docker-compose.yml
More file actions
101 lines (93 loc) · 2.8 KB
/
prod-docker-compose.yml
File metadata and controls
101 lines (93 loc) · 2.8 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
x-server: &base_server_setup
image: risk-module:latest
build:
context: .
restart: unless-stopped
environment:
RISK_ENVIRONMENT: ${RISK_ENVIRONMENT:-PROD}
RISK_API_FQDN: ${RISK_API_FQDN?error}
DJANGO_DEBUG: ${DJANGO_DEBUG:-False}
DJANGO_SECRET_KEY: ${DJANGO_SECRET_KEY?error}
# Database
DATABASE_NAME: ${DATABASE_NAME:-postgres}
DATABASE_USER: ${DATABASE_USER:-postgres}
DATABASE_PASSWORD: ${DATABASE_PASSWORD:-postgres}
DATABASE_HOST: ${DATABASE_HOST:-db}
DATABASE_PORT: ${DATABASE_PORT:-5432}
# Redis
CELERY_REDIS_URL: ${CELERY_REDIS_URL:-redis://redis:6379/0}
CACHE_REDIS_URL: ${CELERY_REDIS_URL:-redis://redis:6379/1}
# PDC
PDC_USERNAME: ${PDC_USERNAME?error}
PDC_PASSWORD: ${PDC_PASSWORD?error}
PDC_ACCESS_TOKEN: ${PDC_ACCESS_TOKEN?error}
# Meteoswiss
METEOSWISS_S3_ENDPOINT_URL: ${METEOSWISS_S3_ENDPOINT_URL?error}
METEOSWISS_S3_BUCKET: ${METEOSWISS_S3_BUCKET?error}
METEOSWISS_S3_ACCESS_KEY: ${METEOSWISS_S3_ACCESS_KEY?error}
METEOSWISS_S3_SECRET_KEY: ${METEOSWISS_S3_SECRET_KEY?error}
env_file:
# NOTE: Pass additional environment using .env
- .env
volumes:
# TODO: Remove host volume for code
- .:/code
- ipython_data_local:/root/.ipython/profile_default # persist ipython data, including ipython history
depends_on:
- db
- redis
services:
db:
image: postgres:12.0-alpine
restart: unless-stopped
environment:
- POSTGRES_DATABASE=postgres
- POSTGRES_USER=postgres
- POSTGRES_PASSWORD=postgres
volumes:
- postgres-data:/var/lib/postgresql/data
redis:
image: redis:alpine
restart: unless-stopped
volumes:
- redis-data:/redis_data
server:
<<: *base_server_setup
command: bash -c "/code/scripts/run_prod.sh"
celery-beat:
<<: *base_server_setup
command: bash -c "/code/scripts/run_worker_beat.sh"
celery:
<<: *base_server_setup
command: bash -c "/code/scripts/run_worker.sh"
deploy: # TODO: Fix memory leak
resources:
limits:
memory: 10GB
caddy:
image: caddy:2.4.6
restart: unless-stopped
environment:
CADDY_EMAIL: ${CADDY_EMAIL?err}
CADDY_HOST_DOMAIN_AZURE: ${CADDY_HOST_DOMAIN_AZURE?err}
CADDY_HOST_DOMAIN_IFRC: ${CADDY_HOST_DOMAIN_IFRC?err}
volumes:
# risk module volumes
- ./storage/static/:/go-risk-module-api/static/
- ./storage/media/:/go-risk-module-api/media/
# Caddyfile volumes
- ./caddy/Caddyfile:/etc/caddy/Caddyfile:ro
- ./caddy/certs:/etc/ssl/caddy/:ro
- caddy_data:/data
- caddy_config:/config
depends_on:
- server
ports:
- "${CADDY_HTTP_PORT:-80}:80"
- "${CADDY_HTTPS_PORT:-443}:443"
volumes:
caddy_data:
caddy_config:
postgres-data:
redis-data:
ipython_data_local: