Start von Service `setup` startet auch `cli`
[demos/kafka/training] / docker / docker-compose.yml
index 2991f81..3820311 100644 (file)
@@ -25,6 +25,7 @@ services:
       - kafka-1-data:/var/lib/kafka/data
     ports:
       - 9081:9081
+    stop_grace_period: 120s
     depends_on:
       - zookeeper
 
@@ -48,6 +49,7 @@ services:
       default:
         aliases:
           - kafka
+    stop_grace_period: 120s
     depends_on:
       - zookeeper
 
@@ -66,6 +68,7 @@ services:
       - kafka-3-data:/var/lib/kafka/data
     ports:
       - 9083:9083
+    stop_grace_period: 120s
     depends_on:
       - zookeeper
 
@@ -111,12 +114,22 @@ services:
     depends_on:
       - schema-registry
 
+  cli:
+    image: juplo/toolbox
+    command: sleep infinity
+    stop_grace_period: 0s
+    depends_on:
+      - kafka-1
+      - kafka-2
+      - kafka-3
+
   setup:
     image: juplo/toolbox
     command:
       - bash
       - -c
       - |
+        cub kafka-ready -b kafka-1:9092,kafka-2:9092,kafka-3:9092 3 60 > /dev/null 2>&1 || exit 1
         if [ -e INITIALIZED ]
         then
           echo -n Bereits konfiguriert: 
@@ -137,10 +150,9 @@ services:
           && kafka-topics --bootstrap-server kafka:9092 --describe --topic test \
           && date > INITIALIZED
         fi
+    stop_grace_period: 0s
     depends_on:
-      - kafka-1
-      - kafka-2
-      - kafka-3
+      - cli
 
   akhq:
     image: tchiotludo/akhq:0.23.0
@@ -163,12 +175,6 @@ services:
       - kafka-2
       - kafka-3
 
-  cli:
-    image: juplo/toolbox
-    command: sleep infinity
-    depends_on:
-      - setup
-
 volumes:
   zookeeper-data:
   zookeeper-log: