JMX ist außerhalb von Docker erreichbar!
[demos/kafka/training] / docker / docker-compose.yml
index 2991f81..9d42dbf 100644 (file)
@@ -21,10 +21,16 @@ services:
       KAFKA_INTER_BROKER_LISTENER_NAME: BROKER
       KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 3
       KAFKA_AUTO_CREATE_TOPICS_ENABLE: "false"
+      KAFKA_OPTS:
+        -Dcom.sun.management.jmxremote=true
+        -Dcom.sun.management.jmxremote.port=9100
+        -Dcom.sun.management.jmxremote.authenticate=false
     volumes:
       - kafka-1-data:/var/lib/kafka/data
     ports:
       - 9081:9081
+      - 9101:9100
+    stop_grace_period: 120s
     depends_on:
       - zookeeper
 
@@ -39,15 +45,21 @@ services:
       KAFKA_INTER_BROKER_LISTENER_NAME: BROKER
       KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 3
       KAFKA_AUTO_CREATE_TOPICS_ENABLE: "false"
+      KAFKA_OPTS:
+        -Dcom.sun.management.jmxremote=true
+        -Dcom.sun.management.jmxremote.port=9100
+        -Dcom.sun.management.jmxremote.authenticate=false
     volumes:
       - kafka-2-data:/var/lib/kafka/data
     ports:
       - 9092:9082
       - 9082:9082
+      - 9102:9100
     networks:
       default:
         aliases:
           - kafka
+    stop_grace_period: 120s
     depends_on:
       - zookeeper
 
@@ -62,10 +74,16 @@ services:
       KAFKA_INTER_BROKER_LISTENER_NAME: BROKER
       KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 3
       KAFKA_AUTO_CREATE_TOPICS_ENABLE: "false"
+      KAFKA_OPTS:
+        -Dcom.sun.management.jmxremote=true
+        -Dcom.sun.management.jmxremote.port=9100
+        -Dcom.sun.management.jmxremote.authenticate=false
     volumes:
       - kafka-3-data:/var/lib/kafka/data
     ports:
       - 9083:9083
+      - 9103:9100
+    stop_grace_period: 120s
     depends_on:
       - zookeeper
 
@@ -111,12 +129,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 +165,21 @@ 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
+
+  zoonavigator:
+    image: elkozmon/zoonavigator:1.1.2
+    ports:
+      - "8000:80"
+    environment:
+      HTTP_PORT: 80
+      CONNECTION_JUPLO_NAME: juplo
+      CONNECTION_JUPLO_CONN: zookeeper:2181
+      AUTO_CONNECT_CONNECTION_ID: JUPLO
+    depends_on:
+      - zookeeper
 
   akhq:
     image: tchiotludo/akhq:0.23.0
@@ -163,12 +202,6 @@ services:
       - kafka-2
       - kafka-3
 
-  cli:
-    image: juplo/toolbox
-    command: sleep infinity
-    depends_on:
-      - setup
-
 volumes:
   zookeeper-data:
   zookeeper-log: