44 lines
1.7 KiB
YAML
44 lines
1.7 KiB
YAML
services:
|
|
kafka:
|
|
image: confluentinc/cp-kafka:7.5.0
|
|
container_name: commandflow-kafka
|
|
hostname: kafka
|
|
ports:
|
|
- "9092:9092"
|
|
environment:
|
|
KAFKA_NODE_ID: 1
|
|
KAFKA_PROCESS_ROLES: broker,controller
|
|
KAFKA_CONTROLLER_QUORUM_VOTERS: 1@kafka:29093
|
|
# Deux listeners :
|
|
# PLAINTEXT → pour les containers Docker entre eux (kafka:29092)
|
|
# PLAINTEXT_HOST → pour les services Python sur la machine hôte (localhost:9092)
|
|
KAFKA_LISTENERS: PLAINTEXT://kafka:29092,PLAINTEXT_HOST://0.0.0.0:9092,CONTROLLER://kafka:29093
|
|
KAFKA_ADVERTISED_LISTENERS: PLAINTEXT://kafka:29092,PLAINTEXT_HOST://localhost:9092
|
|
KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: PLAINTEXT:PLAINTEXT,PLAINTEXT_HOST:PLAINTEXT,CONTROLLER:PLAINTEXT
|
|
KAFKA_INTER_BROKER_LISTENER_NAME: PLAINTEXT
|
|
KAFKA_CONTROLLER_LISTENER_NAMES: CONTROLLER
|
|
KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 1
|
|
KAFKA_TRANSACTION_STATE_LOG_REPLICATION_FACTOR: 1
|
|
KAFKA_TRANSACTION_STATE_LOG_MIN_ISR: 1
|
|
KAFKA_GROUP_INITIAL_REBALANCE_DELAY_MS: 0
|
|
CLUSTER_ID: MkU3OEVBNTcwNTJENDM2Qk
|
|
healthcheck:
|
|
# Vérifie que Kafka accepte des connexions avant de laisser kafdrop démarrer
|
|
test: ["CMD", "kafka-topics", "--bootstrap-server", "localhost:9092", "--list"]
|
|
interval: 10s
|
|
timeout: 10s
|
|
retries: 10
|
|
start_period: 20s
|
|
|
|
kafdrop:
|
|
image: obsidiandynamics/kafdrop:latest
|
|
container_name: commandflow-kafdrop
|
|
hostname: kafdrop # évite un bug DNS du container
|
|
ports:
|
|
- "9000:9000"
|
|
environment:
|
|
KAFKA_BROKERCONNECT: "kafka:29092"
|
|
depends_on:
|
|
kafka:
|
|
condition: service_healthy # attend que Kafka soit vraiment prêt
|
|
restart: on-failure |