forked from TheTreasureMap/gwtm
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdocker-compose.yml
More file actions
108 lines (101 loc) · 2.92 KB
/
docker-compose.yml
File metadata and controls
108 lines (101 loc) · 2.92 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
version: '3.8'
services:
web:
image: gwtm_web:latest
container_name: gwtm-web
ports:
- "8080:8080"
environment:
- DB_USER=${DB_USER}
- DB_PWD=${DB_PWD}
- DB_NAME=${DB_NAME}
- DB_HOST=db
- DB_PORT=5432
- MAIL_PASSWORD=${MAIL_PASSWORD}
- RECAPTCHA_PUBLIC_KEY=${RECAPTCHA_PUBLIC_KEY}
- RECAPTCHA_PRIVATE_KEY=${RECAPTCHA_PRIVATE_KEY}
- ZENODO_ACCESS_KEY=${ZENODO_ACCESS_KEY}
- AWS_ACCESS_KEY_ID=${AWS_ACCESS_KEY_ID}
- AWS_SECRET_ACCESS_KEY=${AWS_SECRET_ACCESS_KEY}
- REDIS_URL=redis://redis:6379/0
depends_on:
- db
- db_init
- redis
- celery_worker
db:
image: postgis/postgis:12-3.5
container_name: gwtm_db
environment:
- DB_USER=${DB_USER}
- DB_PWD=${DB_PWD}
- DB_NAME=${DB_NAME}
- POSTGRES_USER=${DB_USER}
- POSTGRES_PASSWORD=${DB_PWD}
- POSTGRES_DB=${DB_NAME}
- POSTGRES_HOST_AUTH_METHOD=trust
ports:
- "5432:5432"
volumes:
- postgres_data:/var/lib/postgresql/data
command: [
"postgres",
"-c", "shared_preload_libraries=auto_explain",
"-c", "logging_collector=on",
"-c", "log_directory=logs",
"-c", "log_filename=slow.log",
"-c", "log_min_duration_statement=100",
"-c", "auto_explain.log_min_duration=100",
"-c", "auto_explain.log_analyze=true",
"-c", "auto_explain.log_buffers=true",
"-c", "auto_explain.log_timing=true",
"-c", "auto_explain.log_nested_statements=true",
"-c", "auto_explain.log_verbose=true",
"-c", "log_line_prefix='%t [%p]: [%l-1] user=%u,db=%d,app=%a,client=%h '",
"-c", "log_statement=all"
]
healthcheck:
test: [ "CMD-SHELL", "pg_isready -U ${DB_USER} -d ${DB_NAME}" ]
interval: 10s
timeout: 15s
retries: 5
redis:
image: redis:latest
container_name: redis
ports:
- "6379:6379"
celery_worker:
image: gwtm_web:latest
container_name: celery_worker
command: celery -A src.tasks.celery worker --loglevel=info
environment:
- DB_USER=${DB_USER}
- DB_PWD=${DB_PWD}
- DB_NAME=${DB_NAME}
- DB_HOST=db
- DB_PORT=5432
- MAIL_PASSWORD=${MAIL_PASSWORD}
- RECAPTCHA_PUBLIC_KEY=${RECAPTCHA_PUBLIC_KEY}
- RECAPTCHA_PRIVATE_KEY=${RECAPTCHA_PRIVATE_KEY}
- ZENODO_ACCESS_KEY=${ZENODO_ACCESS_KEY}
- AWS_ACCESS_KEY_ID=${AWS_ACCESS_KEY_ID}
- AWS_SECRET_ACCESS_KEY=${AWS_SECRET_ACCESS_KEY}
- REDIS_URL=redis://redis:6379/0
depends_on:
- db
- redis
db_init:
image: gwtm_web:latest
container_name: db_init
command: python -c "from src.models import create_database_tables; create_database_tables()"
environment:
- DB_USER=${DB_USER}
- DB_PWD=${DB_PWD}
- DB_NAME=${DB_NAME}
- DB_HOST=db
- DB_PORT=5432
depends_on:
db:
condition: service_healthy
volumes:
postgres_data: