-
Notifications
You must be signed in to change notification settings - Fork 8
Expand file tree
/
Copy pathdocker-compose.yml
More file actions
134 lines (128 loc) · 3.27 KB
/
docker-compose.yml
File metadata and controls
134 lines (128 loc) · 3.27 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
121
122
123
124
125
126
127
128
129
130
131
132
133
134
services:
migrate:
build:
context: .
dockerfile: Dockerfile
command: python qb_site/manage.py migrate --noinput
volumes:
- .:/app:ro
- appdata:/data
env_file:
- .env
environment:
DJANGO_SETTINGS_MODULE: qb_site.settings.local
DJANGO_DB_HOST: db
DJANGO_DB_PORT: 5432
DJANGO_DB_NAME: queueboard
DJANGO_DB_USER: queueboard
DJANGO_DB_PASSWORD: queueboard
depends_on:
db:
condition: service_healthy
restart: "no"
web:
build:
context: .
dockerfile: Dockerfile
command: python qb_site/manage.py runserver 0.0.0.0:8000
volumes:
- .:/app:ro
- appdata:/data
ports:
- "8000:8000"
env_file:
- .env
environment:
DJANGO_SETTINGS_MODULE: qb_site.settings.local
DJANGO_STATIC_ROOT: /data/staticfiles
DJANGO_MEDIA_ROOT: /data/media
DJANGO_DB_HOST: db
DJANGO_DB_PORT: 5432
DJANGO_DB_NAME: queueboard
DJANGO_DB_USER: queueboard
DJANGO_DB_PASSWORD: queueboard
depends_on:
db:
condition: service_healthy
migrate:
condition: service_completed_successfully
worker:
build:
context: .
dockerfile: Dockerfile
command: >-
celery -A qb_site worker -l info -Q default --concurrency=2 --prefetch-multiplier=1
--max-tasks-per-child=200 --max-memory-per-child=250000 --without-gossip
--without-mingle --uid nobody --gid nogroup
volumes:
- .:/app:ro
- appdata:/data
env_file:
- .env
environment:
PYTHONPATH: /app/qb_site:/app
DJANGO_SETTINGS_MODULE: qb_site.settings.local
DJANGO_DB_HOST: db
DJANGO_DB_PORT: 5432
DJANGO_DB_NAME: queueboard
DJANGO_DB_USER: queueboard
DJANGO_DB_PASSWORD: queueboard
restart: unless-stopped
depends_on:
db:
condition: service_healthy
redis:
condition: service_healthy
migrate:
condition: service_completed_successfully
beat:
build:
context: .
dockerfile: Dockerfile
command: sh -c 'mkdir -p /data && chown -R 65534:65534 /data && exec celery -A qb_site beat -l info --schedule /data/celerybeat-schedule --uid 65534 --gid 65534'
volumes:
- .:/app:ro
- appdata:/data
env_file:
- .env
environment:
PYTHONPATH: /app/qb_site:/app
DJANGO_SETTINGS_MODULE: qb_site.settings.local
DJANGO_DB_HOST: db
DJANGO_DB_PORT: 5432
DJANGO_DB_NAME: queueboard
DJANGO_DB_USER: queueboard
DJANGO_DB_PASSWORD: queueboard
restart: unless-stopped
depends_on:
db:
condition: service_healthy
redis:
condition: service_healthy
migrate:
condition: service_completed_successfully
redis:
image: redis:7-alpine
healthcheck:
test: ["CMD", "redis-cli", "ping"]
interval: 5s
timeout: 5s
retries: 5
db:
image: postgres:16-alpine
ports:
- "5432:5432"
environment:
POSTGRES_DB: queueboard
POSTGRES_USER: queueboard
POSTGRES_PASSWORD: queueboard
volumes:
- pgdata:/var/lib/postgresql/data
healthcheck:
test: ["CMD-SHELL", "pg_isready -U queueboard"]
interval: 5s
timeout: 5s
retries: 5
volumes:
pgdata:
appdata: