-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdocker-compose.yml
102 lines (90 loc) · 3.69 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
version: '3.8'
services:
web-app:
build:
context: .
ports:
- "8000:8000"
volumes:
- ./service:/service
environment:
- DB_HOST=database-1
- DB_NAME=dbname
- DB_USER=dbuser
- DB_PASS=pass
command: >
sh -c "python manage.py runserver 0.0.0.0:8000"
depends_on:
- database-1
database-1:
container_name: database-2
image: postgres:17-alpine
environment:
- POSTGRES_DB=dbname
- POSTGRES_USER=dbuser
- POSTGRES_PASSWORD=pass
ports:
- 5432:5432
volumes:
- postgres_new_data:/var/lib/postgresql/data/
redis:
image: redis:7.0.5-alpine
hostname: redis
worker:
build:
context: .
hostname: worker
#Команда entrypoint: celery задаёт основную команду, которая будет запускаться в контейнере при его старте.
#эта команнда позвоялет вызывать дургие команды этому сервису
entrypoint: celery
command: -A celery_app.app worker --loglevel=info
volumes:
- ./service:/service
#В docker-compose, директива links используется для связи контейнеров, чтобы они могли обращаться друг к другу по именам хостов. Когда контейнеры запускаются с использованием docker-compose, links позволяет одному контейнеру подключаться к другому с использованием DNS-имени контейнера, указанного в links. Это было полезно в старых версиях Docker, но в последних версиях рекомендуется использовать сеть (network) вместо links.
links:
- redis
depends_on:
- redis
- database-1
environment:
- DB_HOST=database-1
- DB_NAME=dbname
- DB_USER=dbuser
- DB_PASS=pass
worker2:
build:
context: .
hostname: worker2
#Команда entrypoint: celery задаёт основную команду, которая будет запускаться в контейнере при его старте.
#эта команнда позвоялет вызывать дургие команды этому сервису
entrypoint: celery
command: -A celery_app.app worker --loglevel=info
volumes:
- ./service:/service
#В docker-compose, директива links используется для связи контейнеров, чтобы они могли обращаться друг к другу по именам хостов. Когда контейнеры запускаются с использованием docker-compose, links позволяет одному контейнеру подключаться к другому с использованием DNS-имени контейнера, указанного в links. Это было полезно в старых версиях Docker, но в последних версиях рекомендуется использовать сеть (network) вместо links.
links:
- redis
depends_on:
- redis
- database-1
environment:
- DB_HOST=database-1
- DB_NAME=dbname
- DB_USER=dbuser
- DB_PASS=pass
flower:
build:
context: .
hostname: flower
entrypoint: celery
command: -A celery_app.app flower --port=5555
volumes:
- ./service:/service
links:
- redis
depends_on:
- redis
ports:
- "5555:5555"
volumes:
postgres_new_data: