Schönere YAML-Syntax für `setup`-Service
[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   schema-registry:
73     image: confluentinc/cp-schema-registry:7.5.1
74     environment:
75       SCHEMA_REGISTRY_KAFKASTORE_BOOTSTRAP_SERVERS: kafka-1:9092,kafka-2:9092,kafka-3:9092
76       SCHEMA_REGISTRY_HOST_NAME: schema-registry
77       SCHEMA_REGISTRY_LISTENERS: http://0.0.0.0:8085
78       SCHEMA_REGISTRY_LOG4J_ROOT_LOGLEVEL: INFO
79     ports:
80       - 8085:8085
81     depends_on:
82       - kafka-1
83       - kafka-2
84       - kafka-3
85
86   connect:
87     image: confluentinc/cp-kafka-connect:7.5.1
88     environment:
89       CONNECT_BOOTSTRAP_SERVERS: kafka-1:9092,kafka-2:9092,kafka-3:9092
90       CONNECT_REST_PORT: 8083
91       CONNECT_REST_LISTENERS: http://0.0.0.0:8083
92       CONNECT_REST_ADVERTISED_HOST_NAME: connect
93       CONNECT_CONFIG_STORAGE_TOPIC: __connect-config
94       CONNECT_OFFSET_STORAGE_TOPIC: __connect-offsets
95       CONNECT_STATUS_STORAGE_TOPIC: __connect-status
96       CONNECT_GROUP_ID: kafka-connect
97       CONNECT_KEY_CONVERTER_SCHEMAS_ENABLE: "true"
98       CONNECT_KEY_CONVERTER: io.confluent.connect.avro.AvroConverter
99       CONNECT_KEY_CONVERTER_SCHEMA_REGISTRY_URL: http://schema-registry:8085
100       CONNECT_VALUE_CONVERTER_SCHEMAS_ENABLE: "true"
101       CONNECT_VALUE_CONVERTER: io.confluent.connect.avro.AvroConverter
102       CONNECT_VALUE_CONVERTER_SCHEMA_REGISTRY_URL: http://schema-registry:8085
103       CONNECT_INTERNAL_KEY_CONVERTER: org.apache.kafka.connect.json.JsonConverter
104       CONNECT_INTERNAL_VALUE_CONVERTER: org.apache.kafka.connect.json.JsonConverter
105       CONNECT_OFFSET_STORAGE_REPLICATION_FACTOR: 1
106       CONNECT_CONFIG_STORAGE_REPLICATION_FACTOR: 1
107       CONNECT_STATUS_STORAGE_REPLICATION_FACTOR: 1
108       CONNECT_PLUGIN_PATH: /usr/share/java/
109     ports:
110       - 8083:8083
111     depends_on:
112       - schema-registry
113
114   setup:
115     image: juplo/toolbox
116     command:
117       - bash
118       - -c
119       - |
120         if [ -e INITIALIZED ]
121         then
122           echo -n Bereits konfiguriert: 
123           cat INITIALIZED
124           kafka-topics --bootstrap-server kafka:9092 --describe --topic test
125         else
126           kafka-topics --bootstrap-server kafka:9092 \
127                        --delete \
128                        --if-exists \
129                        --topic test
130           kafka-topics --bootstrap-server kafka:9092 \
131                        --create \
132                        --topic test \
133                        --partitions 2 \
134                        --replication-factor 3 \
135                        --config min.insync.replicas=2 \
136           && echo Das Topic \'test\' wurde erfolgreich angelegt: \
137           && kafka-topics --bootstrap-server kafka:9092 --describe --topic test \
138           && date > INITIALIZED
139         fi
140     depends_on:
141       - kafka-1
142       - kafka-2
143       - kafka-3
144
145   akhq:
146     image: tchiotludo/akhq:0.23.0
147     ports:
148       - 8888:8080
149     environment:
150       AKHQ_CONFIGURATION: |
151         akhq:
152           connections:
153             docker-kafka-server:
154               properties:
155                 bootstrap.servers: "kafka:9092"
156               schema-registry:
157                 url: "http://schema-registry:8085"
158               connect:
159                 - name: "connect"
160                   url: "http://connect:8083"
161     depends_on:
162       - kafka-1
163       - kafka-2
164       - kafka-3
165
166   cli:
167     image: juplo/toolbox
168     command: sleep infinity
169     depends_on:
170       - setup
171
172 volumes:
173   zookeeper-data:
174   zookeeper-log:
175   kafka-1-data:
176   kafka-2-data:
177   kafka-3-data: