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