kafka-ui-with-jmx-exporter.yaml 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. ---
  2. version: '2'
  3. services:
  4. kafka0:
  5. image: confluentinc/cp-kafka:7.2.1
  6. hostname: kafka0
  7. container_name: kafka0
  8. ports:
  9. - "9092:9092"
  10. - "11001:11001"
  11. environment:
  12. KAFKA_BROKER_ID: 1
  13. KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: 'CONTROLLER:PLAINTEXT,PLAINTEXT:PLAINTEXT,PLAINTEXT_HOST:PLAINTEXT'
  14. KAFKA_ADVERTISED_LISTENERS: 'PLAINTEXT://kafka0:29092,PLAINTEXT_HOST://localhost:9092'
  15. KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 1
  16. KAFKA_GROUP_INITIAL_REBALANCE_DELAY_MS: 0
  17. KAFKA_TRANSACTION_STATE_LOG_MIN_ISR: 1
  18. KAFKA_TRANSACTION_STATE_LOG_REPLICATION_FACTOR: 1
  19. KAFKA_PROCESS_ROLES: 'broker,controller'
  20. KAFKA_NODE_ID: 1
  21. KAFKA_CONTROLLER_QUORUM_VOTERS: '1@kafka0:29093'
  22. KAFKA_LISTENERS: 'PLAINTEXT://kafka0:29092,CONTROLLER://kafka0:29093,PLAINTEXT_HOST://0.0.0.0:9092'
  23. KAFKA_INTER_BROKER_LISTENER_NAME: 'PLAINTEXT'
  24. KAFKA_CONTROLLER_LISTENER_NAMES: 'CONTROLLER'
  25. KAFKA_LOG_DIRS: '/tmp/kraft-combined-logs'
  26. KAFKA_OPTS: -javaagent:/usr/share/jmx_exporter/jmx_prometheus_javaagent.jar=11001:/usr/share/jmx_exporter/kafka-broker.yml
  27. volumes:
  28. - ./jmx-exporter:/usr/share/jmx_exporter/
  29. - ./scripts/update_run.sh:/tmp/update_run.sh
  30. command: "bash -c 'if [ ! -f /tmp/update_run.sh ]; then echo \"ERROR: Did you forget the update_run.sh file that came with this docker-compose.yml file?\" && exit 1 ; else /tmp/update_run.sh && /usr/share/jmx_exporter/kafka-prepare-and-run ; fi'"
  31. kafka-ui:
  32. container_name: kafka-ui
  33. image: provectuslabs/kafka-ui:latest
  34. ports:
  35. - 8080:8080
  36. depends_on:
  37. - kafka0
  38. environment:
  39. KAFKA_CLUSTERS_0_NAME: local
  40. KAFKA_CLUSTERS_0_BOOTSTRAPSERVERS: kafka0:29092
  41. KAFKA_CLUSTERS_0_METRICS_PORT: 11001
  42. KAFKA_CLUSTERS_0_METRICS_TYPE: PROMETHEUS