docker/docker-compose-cp.yaml (43 lines of code) (raw):
version: '3.5'
services:
zookeeper:
image: 'confluentinc/cp-zookeeper:7.4.0'
hostname: 'zookeeper'
ports:
- '2181:2181'
environment:
- 'ZOOKEEPER_CLIENT_PORT=2181'
- 'ZOOKEEPER_TICK_TIME=2000'
restart: 'on-failure'
kafka:
# "`-._,-'"`-._,-'"`-._,-'"`-._,-'"`-._,-'"`-._,-'"`-._,-'"`-._,-'"`-._,-
# An important note about accessing Kafka from clients on other machines:
# -----------------------------------------------------------------------
#
# The config used here exposes port 9092 for _external_ connections to the broker
# i.e. those from _outside_ the docker network. This could be from the host machine
# running docker, or maybe further afield if you've got a more complicated setup.
# If the latter is true, you will need to change the value 'localhost' in
# KAFKA_ADVERTISED_LISTENERS to one that is resolvable to the docker host from those
# remote clients
#
# For connections _internal_ to the docker network, such as from other services
# and components, use kafka:29092.
#
# See https://rmoff.net/2018/08/02/kafka-listeners-explained/ for details
# "`-._,-'"`-._,-'"`-._,-'"`-._,-'"`-._,-'"`-._,-'"`-._,-'"`-._,-'"`-._,-
#
image: 'confluentinc/cp-kafka:7.4.0'
hostname: 'kafka'
depends_on:
- 'zookeeper'
ports:
- '9092:9092'
environment:
- 'KAFKA_BROKER_ID=1'
- 'KAFKA_ZOOKEEPER_CONNECT=zookeeper:2181'
- 'KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://kafka:29092,PLAINTEXT_HOST://localhost:9092'
- 'KAFKA_LISTENER_SECURITY_PROTOCOL_MAP=PLAINTEXT:PLAINTEXT,PLAINTEXT_HOST:PLAINTEXT'
- 'KAFKA_INTER_BROKER_LISTENER_NAME=PLAINTEXT'
- 'KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR=1'
- 'KAFKA_TRANSACTION_STATE_LOG_REPLICATION_FACTOR=1'
- 'KAFKA_TRANSACTION_STATE_LOG_MIN_ISR=1'
- 'KAFKA_AUTHORIZER_CLASS_NAME=kafka.security.authorizer.AclAuthorizer'
- 'KAFKA_ALLOW_EVERYONE_IF_NO_ACL_FOUND=true'
restart: 'on-failure'
schema-registry:
image: 'confluentinc/cp-schema-registry:7.4.0'
hostname: 'schema-registry'
depends_on:
- 'zookeeper'
- 'kafka'
ports:
- '8081:8081'
environment:
SCHEMA_REGISTRY_KAFKASTORE_BOOTSTRAP_SERVERS: 'PLAINTEXT://kafka:29092'
SCHEMA_REGISTRY_HOST_NAME: 'schema-registry'
SCHEMA_REGISTRY_KAFKASTORE_CONNECTION_URL: 'zookeeper:2181'
#SCHEMA_REGISTRY_MODE_MUTABILITY: 'true'
restart: 'on-failure'