1、下载镜像
docker pull wurstmeister/zookeeper
docker pull wurstmeister/kafka
2、启动
#启动zookeeper
docker run -d --name zookeeper -p 2181:2181 -t wurstmeister/zookeeper
#启动kafka
docker run -d --name kafka -p 9092:9092 --link zookeeper --env KAFKA_ZOOKEEPER_CONNECT=zookeeper:2181 --env KAFKA_ADVERTISED_HOST_NAME=localhost --env KAFKA_ADVERTISED_PORT=9092 --volume /etc/localtime:/etc/localtime wurstmeister/kafka
3、测试
#进入kafka
docker exec -it ${CONTAINER ID} /bin/bash
cd /opt/kafka_2.12-2.1.0/bin
#创建一个主题
kafka-topics.sh --create --zookeeper zookeeper:2181 --replication-factor 1 --partitions 1 --topic mykafka
#运行一个消息生产者,指定topic为刚刚创建的主题
bin/kafka-console-producer.sh --broker-list localhost:9092 --topic mykafka
#运行一个消费者,指定同样的主题
bin/kafka-console-consumer.sh -bootstrap-server localhost:9092 -topic mykafka (从头消费 -from-beginning)
# 允许外部端口连接
cd /opt/kafka_2.12-2.1.0/config
sed -i 's/#listeners=PLAINTEXT:\/\/:9092/listeners=PLAINTEXT:\/\/0.0.0.0:9092/g' server.properties
sed -i 's/#advertised.listeners=PLAINTEXT:\/\/your.host.name:9092/advertised.listeners=PLAINTEXT:\/\/124.223.167.7:9092/g' server.properties
# 重启kafka
docker restart ${CONTAINER ID}
使用Dokcer快速搭建kafka
于 2022-07-27 14:16:37 首次发布