首先创建一个网络
#app-queue:网络名称 应用层
#–driver:网络类型为bridge
docker network create app-queue --driver bridge
安装zookeeper
docker run -d --name zookeeper \
--restart=always \
--network app-queue \
-e ALLOW_ANONYMOUS_LOGIN=yes \
bitnami/zookeeper:latest
docker logs -f --tail 200 zookeeper
安装Kafka
安装并运行Kafka,
–name:容器名称
-p:设置映射端口(默认9092 )
-d:后台启动
ALLOW_PLAINTEXT_LISTENER任何人可以访问
KAFKA_AUTO_CREATE_TOPICS_ENABLE=false 禁止自动创建主题
KAFKA_CFG_ZOOKEEPER_CONNECT链接的zookeeper
ALLOW_PLAINTEXT_LISTENER任何人可以访问
KAFKA_CFG_ZOOKEEPER_CONNECT链接的zookeeper
KAFKA_CFG_ADVERTISED_LISTENERS当前主机IP或地址(重点:如果是服务器部署则配服务器IP或域名否则客户端监听消息会报地址错误)
docker run -d --name kafka \
--restart=always \
--network app-queue \
-p 9092:9092 \
-e ALLOW_PLAINTEXT_LISTENER=yes \
-e KAFKA_AUTO_CREATE_TOPICS_ENABLE=false \
-e KAFKA_CFG_ZOOKEEPER_CONNECT=zookeeper:2181 \
-e KAFKA_CFG_ADVERTISED_LISTENERS=PLAINTEXT://192.168.3.102:9092 \
bitnami/kafka:latest
docker logs -f --tail 200 kafka
安装kafka-manager图形化管理工具(不好用)
kafka-manager 只是一个简单的页面,浏览kafka中的信息,没有实际操作功能。
-p:设置映射端口(默认9000)
–name:容器名称
-ZK_HOSTS:zookeeper服务地址,多个可用逗号隔开
docker run --name kafka-manager -d \
--restart=always \
--network app-queue \
-p 9000:9000 \
-e ZK_HOSTS="zookeeper:2181" \
sheepkiller/kafka-manager
docker logs -f --tail 200 kafka-manager
安装kafka-map图形化管理工具(好用)
图形化管理工具
访问地址:http://服务器IP:9001/
DEFAULT_USERNAME:默认账号admin
DEFAULT_PASSWORD:默认密码admin
Git 地址:https://github.com/dushixiang/kafka-map/blob/master/README-zh_CN.md
docker run -d --name kafka-map \
--network app-queue \
-p 9001:8080 \
-v /home/kafka/kafka-map:/usr/local/kafka-map/data \
-e DEFAULT_USERNAME=admin \
-e DEFAULT_PASSWORD=admin \
--restart always dushixiang/kafka-map:latest
查看Kafka版本号
docker exec -it kafka /bin/bash
find / -name \*kafka_\* | head -1 | grep -o '\kafka[^\n]*'
kafka/libs/kafka_2.12-3.5.1.jar