-
Notifications
You must be signed in to change notification settings - Fork 0
/
docker-compose.yml
82 lines (75 loc) · 1.88 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
version: '3.8'
services:
zookeeper:
image: 'bitnami/zookeeper:latest'
environment:
- ALLOW_ANONYMOUS_LOGIN=yes
ports:
- '2181:2181'
kafka:
image: 'bitnami/kafka:latest'
environment:
- KAFKA_BROKER_ID=1
- KAFKA_ZOOKEEPER_CONNECT=zookeeper:2181
- ALLOW_PLAINTEXT_LISTENER=yes
- KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://kafka:9092
- KAFKA_LISTENERS=PLAINTEXT://0.0.0.0:9092
- KAFKA_CREATE_TOPICS="messages:1:1"
ports:
- '9092:9092'
depends_on:
- zookeeper
healthcheck:
test: ["CMD-SHELL", "kafka-topics.sh --bootstrap-server kafka:9092 --list || exit 1"]
interval: 10s
timeout: 5s
retries: 5
db:
image: postgres:13
container_name: postgres
environment:
POSTGRES_DB: messages_db
POSTGRES_USER: user
POSTGRES_PASSWORD: password
ports:
- "5432:5432"
healthcheck:
test: [ "CMD-SHELL", "pg_isready -d messages_db -U user" ]
interval: 5s
timeout: 5s
retries: 5
migrator:
image: migrate/migrate
depends_on:
db:
condition: service_healthy
command: [ "-path", "/migrations", "-database", "postgresql://user:password@db:5432/messages_db?sslmode=disable", "up" ]
volumes:
- ./migrations:/migrations
server:
build:
context: ./server
dockerfile: Dockerfile
ports:
- "5001:5001"
depends_on:
db:
condition: service_healthy
kafka:
condition: service_healthy
worker:
build:
context: ./worker
dockerfile: Dockerfile
depends_on:
db:
condition: service_healthy
kafka:
condition: service_healthy
kafka-init:
image: 'bitnami/kafka:latest'
depends_on:
- kafka
entrypoint: [ "bash", "-c", "sleep 10 && /check_kafka_topic.sh" ]
volumes:
- ./check_kafka_topic.sh:/check_kafka_topic.sh