单节点模式(在一台机器上部署):
docker run -d --restart=always --name zookeeper --publish 2181:2181 --volume /etc/localtime:/etc/localtime zookeeper:latest
docker run -d --restart=always --name kafka --publish 9092:9092 --link zookeeper --env KAFKA_ZOOKEEPER_CONNECT=zookeeper:2181 --env KAFKA_ADVERTISED_HOST_NAME=换成机器IP --env KAFKA_ADVERTISED_PORT=9092 --volume /etc/localtime:/etc/localtime wurstmeister/kafka:latest
验证消息是否可以正常生产和消费:
进入kafka容器(A会话):
kafka-topics.sh --create --zookeeper 换成机器IP:2181 --partitions 1 --replication-factor 1 --topic test
kafka-console-producer.sh --broker-list 换成机器IP:9092 --topic test
复制一个会话,再次进入kafka容器(B会话):
kafka-console-consumer.sh --bootstrap-server 换成机器IP:9092 --topic test --from-beginning
此时在A会话中随意敲击任意字母数字后回车,即可在B会话中看到你所敲击的字母数字,则表示服务正常运行。
三节点集群模式:
A机器运行命令(先运行zookeeper):
docker run -d --name zoo-1 --restart always -e zk_id=1 -e zk_server.1=0.0.0.0:2888:3888 -e zk_server.2=B机器IP:2888:3888 -e zk_server.3=C机器IP:2888:3888 -p 2181:2181 -p 2888:2888 -p 3888:3888 zookeeper:latest
B机器运行命令:
docker run -d --name zoo-2 --restart always -e zk_id=2 -e zk_server.1=A机器IP:2888:3888 -e zk_server.2=0.0.0.0:2888:3888 -e zk_server.3=C机器IP:2888:3888 -p 2181:2181 -p 2888:2888 -p 3888:3888 zookeeper:latest
C机器运行命令:
docker run -d --name zoo-3 --restart always -e zk_id=3 -e zk_server.1=A机器IP:2888:3888 -e zk_server.2=B机器IP:2888:3888 -e zk_server.3=0.0.0.0:2888:3888 -p 2181:2181 -p 2888:2888 -p 3888:3888 zookeeper:latest
A机器运行命令(再运行kafka):
docker run -d --name kafka-1 --restart always -e KAFKA_BROKER_ID=1 -e KAFKA_ZOOKEEPER_CONNECT=A机器IP:2181,B机器IP:2181,C机器IP:2181 -e KAFKA_ADVERTISED_HOST_NAME=A机器IP -e KAFKA_DELETE_TOPIC_ENABLE=true -e KAFKA_ADVERTISED_PORT=9092 -p 9092:9092 wurstmeister/kafka:latest
B机器运行命令:
docker run -d --name kafka-2 --restart always -e KAFKA_BROKER_ID=2 -e KAFKA_ZOOKEEPER_CONNECT=A机器IP:2181,B机器IP:2181,C机器IP:2181 -e KAFKA_ADVERTISED_HOST_NAME=B机器IP -e KAFKA_DELETE_TOPIC_ENABLE=true -e KAFKA_ADVERTISED_PORT=9092 -p 9092:9092 wurstmeister/kafka:latest
C机器运行命令:
docker run -d --name kafka-3 --restart always -e KAFKA_BROKER_ID=3 -e KAFKA_ZOOKEEPER_CONNECT=A机器IP:2181,B机器IP:2181,C机器IP:2181 -e KAFKA_ADVERTISED_HOST_NAME=C机器IP -e KAFKA_DELETE_TOPIC_ENABLE=true -e KAFKA_ADVERTISED_PORT=9092 -p 9092:9092 wurstmeister/kafka:latest
验证三节点集群是否可以正常生产和消费消息:
进入A机器kafka容器:
kafka-topics.sh --create --zookeeper A机器IP:2181,B机器IP:2181,C机器IP:2181 --partitions 3 --replication-factor 3 --topic test
kafka-console-producer.sh --broker-list A机器IP:9092 --topic test
进入B或C机器kafka容器:
kafka-console-consumer.sh --bootstrap-server B机器IP:9092 --topic test --from-beginning
此时在A机器窗口中随意敲击任意字母数字后回车,即可在B、C机器窗口中看到你所敲击的字母数字,则表示集群正常运行。