ead627486a09c84783b3468f168126e3cbe2bb3d
[demos/kafka/training] / docker / docker-compose.yml
1 version: '3.2'
2 services:
3   zookeeper:
4     image: confluentinc/cp-zookeeper:7.5.1
5     environment:
6       ZOOKEEPER_CLIENT_PORT: 2181
7     ports:
8       - 2181:2181
9
10   kafka-1:
11     image: confluentinc/cp-kafka:7.5.1
12     environment:
13       KAFKA_ZOOKEEPER_CONNECT: zookeeper:2181
14       KAFKA_LISTENERS: BROKER://:9092, LOCALHOST://:9081
15       KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: BROKER:PLAINTEXT, LOCALHOST:PLAINTEXT
16       KAFKA_ADVERTISED_LISTENERS: BROKER://kafka-1:9092, LOCALHOST://localhost:9081
17       KAFKA_BROKER_ID: 1
18       KAFKA_INTER_BROKER_LISTENER_NAME: BROKER
19       KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 3
20       KAFKA_AUTO_CREATE_TOPICS_ENABLE: "false"
21     ports:
22       - 9081:9081
23     depends_on:
24       - zookeeper
25
26   kafka-2:
27     image: confluentinc/cp-kafka:7.5.1
28     environment:
29       KAFKA_ZOOKEEPER_CONNECT: zookeeper:2181
30       KAFKA_LISTENERS: BROKER://:9092, LOCALHOST://:9082
31       KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: BROKER:PLAINTEXT, LOCALHOST:PLAINTEXT
32       KAFKA_ADVERTISED_LISTENERS: BROKER://kafka-2:9092, LOCALHOST://localhost:9082
33       KAFKA_BROKER_ID: 2
34       KAFKA_INTER_BROKER_LISTENER_NAME: BROKER
35       KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 3
36       KAFKA_AUTO_CREATE_TOPICS_ENABLE: "false"
37     ports:
38       - 9092:9082
39       - 9082:9082
40     networks:
41       default:
42         aliases:
43           - kafka
44     depends_on:
45       - zookeeper
46
47   kafka-3:
48     image: confluentinc/cp-kafka:7.5.1
49     environment:
50       KAFKA_ZOOKEEPER_CONNECT: zookeeper:2181
51       KAFKA_LISTENERS: BROKER://:9092, LOCALHOST://:9083
52       KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: BROKER:PLAINTEXT, LOCALHOST:PLAINTEXT
53       KAFKA_ADVERTISED_LISTENERS: BROKER://kafka-3:9092, LOCALHOST://localhost:9083
54       KAFKA_BROKER_ID: 3
55       KAFKA_INTER_BROKER_LISTENER_NAME: BROKER
56       KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 3
57       KAFKA_AUTO_CREATE_TOPICS_ENABLE: "false"
58     ports:
59       - 9083:9083
60     depends_on:
61       - zookeeper
62
63   setup:
64     image: juplo/toolbox
65     command: >
66       bash -c "
67         kafka-topics --bootstrap-server kafka:9092 --delete --if-exists --topic test
68         kafka-topics --bootstrap-server kafka:9092 --create --topic test --partitions 2 --replication-factor 3 --config min.insync.replicas=2
69         echo Das Topic \'test\' wurde erfolgreich angelegt:
70         kafka-topics --bootstrap-server kafka:9092 --describe --topic test
71         echo \'docker-compose restart -t0 setup\' löscht das Topic und legt es neu an
72         sleep infinity
73       "
74     depends_on:
75       - kafka-1
76       - kafka-2
77       - kafka-3
78
79   akhq:
80     image: tchiotludo/akhq:0.23.0
81     ports:
82       - 8888:8080
83     environment:
84       AKHQ_CONFIGURATION: |
85         akhq:
86           connections:
87             docker-kafka-server:
88               properties:
89                 bootstrap.servers: "kafka:9092"
90     depends_on:
91       - kafka-1
92       - kafka-2
93       - kafka-3
94
95   cli:
96     image: juplo/toolbox
97     command: sleep infinity
98     depends_on:
99       - setup