Merge branch 'stored-state' into stored-offsets
[demos/kafka/training] / docker-compose.yml
1 version: '3.2'
2 services:
3   zookeeper:
4     image: confluentinc/cp-zookeeper:7.0.2
5     environment:
6       ZOOKEEPER_CLIENT_PORT: 2181
7     ports:
8       - 2181:2181
9
10   kafka:
11     image: confluentinc/cp-kafka:7.0.2
12     environment:
13       KAFKA_BROKER_ID: 1
14       KAFKA_ZOOKEEPER_CONNECT: zookeeper:2181
15       KAFKA_LISTENERS: DOCKER://:9092, LOCALHOST://:9082
16       KAFKA_ADVERTISED_LISTENERS: DOCKER://kafka:9092, LOCALHOST://localhost:9082
17       KAFKA_INTER_BROKER_LISTENER_NAME: DOCKER
18       KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: DOCKER:PLAINTEXT, LOCALHOST:PLAINTEXT
19       KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 1
20       KAFKA_AUTO_CREATE_TOPICS_ENABLE: "false"
21     ports:
22       - 9092:9082
23       - 9082:9082
24     depends_on:
25       - zookeeper
26
27   mongo:
28     image: mongo:4.4
29     ports:
30       - 27017:27017
31     environment:
32       MONGO_INITDB_ROOT_USERNAME: juplo
33       MONGO_INITDB_ROOT_PASSWORD: training
34
35   express:
36     image: mongo-express
37     ports:
38       - 8090:8081
39     environment:
40       ME_CONFIG_MONGODB_ADMINUSERNAME: juplo
41       ME_CONFIG_MONGODB_ADMINPASSWORD: training
42       ME_CONFIG_MONGODB_URL: mongodb://juplo:training@mongo:27017/
43
44   setup:
45     image: juplo/toolbox
46     command: >
47       bash -c "
48         kafka-topics --bootstrap-server kafka:9092 --delete --if-exists --topic test
49         kafka-topics --bootstrap-server kafka:9092 --create --topic test --partitions 2
50       "
51
52   cli:
53     image: juplo/toolbox
54     command: sleep infinity
55
56   producer:
57     image: juplo/endless-producer:1.0-SNAPSHOT
58     ports:
59       - 8000:8080
60     environment:
61       producer.bootstrap-server: kafka:9092
62       producer.client-id: producer
63       producer.topic: test
64       producer.throttle-ms: 500
65
66
67   peter:
68     image: juplo/endless-consumer:1.0-SNAPSHOT
69     ports:
70       - 8081:8081
71     environment:
72       consumer.bootstrap-server: kafka:9092
73       consumer.client-id: peter
74       consumer.topic: test
75       spring.data.mongodb.uri: mongodb://juplo:training@mongo:27017
76       spring.data.mongodb.database: juplo
77
78   beate:
79     image: juplo/endless-consumer:1.0-SNAPSHOT
80     ports:
81       - 8082:8081
82     environment:
83       consumer.bootstrap-server: kafka:9092
84       consumer.client-id: beate
85       consumer.topic: test
86       spring.data.mongodb.uri: mongodb://juplo:training@mongo:27017
87       spring.data.mongodb.database: juplo