-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdocker-compose.yml
131 lines (122 loc) · 2.84 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
services:
db:
image: rasulkireev/custom-postgres:15
volumes:
- postgres_data:/var/lib/postgresql/data
ports:
- "5432:5432"
environment:
- POSTGRES_DB=seo_blog_bot
- POSTGRES_USER=seo_blog_bot
- POSTGRES_PASSWORD=seo_blog_bot
healthcheck:
test: ["CMD-SHELL", "pg_isready -U seo_blog_bot"]
interval: 5s
timeout: 5s
retries: 5
redis:
image: redis:7-alpine
command: redis-server --requirepass seo_blog_bot
ports:
- "6379:6379"
volumes:
- redis_data:/data
environment:
- REDIS_PASSWORD=seo_blog_bot
backend:
build:
context: .
dockerfile: Dockerfile-python
working_dir: /app
command: sh -c "python manage.py migrate && python manage.py runserver 0.0.0.0:8000"
volumes:
- .:/app
ports:
- "8000:8000"
depends_on:
db:
condition: service_healthy
redis:
condition: service_started
frontend:
condition: service_started
env_file:
- .env
workers:
build:
context: .
dockerfile: Dockerfile-python
working_dir: /app
command: python manage.py qcluster
volumes:
- .:/app
depends_on:
db:
condition: service_healthy
redis:
condition: service_started
env_file:
- .env
frontend:
image: node:18
working_dir: /app
command: sh -c "npm install && npm run start"
volumes:
- .:/app
ports:
- "9091:9091"
mailhog:
image: mailhog/mailhog
expose:
- 1025
- 8025
ports:
- "1025:1025"
- "8025:8025"
stripe:
image: stripe/stripe-cli:latest
command: [
"listen",
"-H", "x-djstripe-webhook-secret: ${DJSTRIPE_WEBHOOK_SECRET}",
"--forward-to", "http://backend:8000/stripe/webhook/"
]
environment:
- STRIPE_API_KEY=${STRIPE_TEST_SECRET_KEY}
- STRIPE_DEVICE_NAME=djstripe_docker
- DJSTRIPE_WEBHOOK_SECRET=${DJSTRIPE_WEBHOOK_SECRET}
dns:
- 8.8.8.8
- 8.8.4.4
minio:
image: minio/minio
ports:
- "9000:9000"
- "9001:9001"
volumes:
- minio_data:/data
environment:
MINIO_ROOT_USER: seo_blog_bot
MINIO_ROOT_PASSWORD: seo_blog_bot
command: server --console-address ":9001" /data
healthcheck:
test: ["CMD", "curl", "-f", "http://localhost:9000/minio/health/live"]
interval: 5s
timeout: 5s
retries: 3
createbuckets:
image: minio/mc
depends_on:
minio:
condition: service_healthy
entrypoint: >
/bin/sh -c "
sleep 5 &&
/usr/bin/mc config host add myminio http://minio:9000 seo_blog_bot seo_blog_bot &&
/usr/bin/mc mb myminio/seo-blog-bot-dev &&
/usr/bin/mc anonymous set download myminio/seo-blog-bot-dev &&
exit 0;
"
volumes:
postgres_data:
redis_data:
minio_data: