Docker部署Kafka 2.8.1(保姆级图文教程)
创作时间:
作者:
@小白创作中心
Docker部署Kafka 2.8.1(保姆级图文教程)
引用
CSDN
1.
https://blog.csdn.net/donkor_/article/details/140362446
本文将详细介绍如何使用Docker部署Kafka 2.8.1。内容包括环境准备、Zookeeper的安装与启动、Kafka的安装与启动以及测试步骤。每一步都配有具体的命令和解释,适合初学者学习。
一、环境
名称 | 备注 |
---|---|
操作命令对象 | Docker 版本26.1.3 |
远程操作系统 | CentOS 7.9 64位 |
远程管理工具 | FinalShell 版本4.3.11 |
安装软件名称 | zookeeper 版本3.4.13 |
安装软件名称 | Kafka 版本2.8.1 |
二、安装并启动zookeeper
在安装Kafka之前需要先安装zookeeper,因为Kafka启动会将元数据保存在zookeeper中,zookeeper是一种分布式协调服务,可以在分布式系统中共享配置,协调锁资源,提供命名服务。如果已经安装了zookeeper,直接跳过此步骤。
2.1 查找 Docker Hub 上的 zookeeper 镜像
docker search wurstmeister/zookeeper
2.2 拉取zookeeper镜像
没写tag默认安装最新版本
docker pull wurstmeister/zookeeper
2.3 启动zookeeper镜像
docker run --restart=always \
--log-driver json-file \
--log-opt max-size=100m \
--log-opt max-file=2 \
--name zookeeper -p 2181:2181 \
-v /etc/localtime:/etc/localtime \
-d wurstmeister/zookeeper
命令 注释
- --restart=always 表示容器退出时总是重启
- --log-driver json-file 表示使用 JSON 文件作为日志驱动
- --log-opt max-size=100m 表示设置日志的最大大小为100MB
- --log-opt max-file=2 表示设置日志文件的最大数量
- --name 表示容器命名
- -p 表示端口映射
- -v /etc/localtime:/etc/localtime 表示将本地时间映射到容器中
- -d 表示后台运行
2.4 查看zookeeper容器是否运行
三、安装并启动Kafka
3.1 查找 Docker Hub 上的 Kafka 镜像
docker search wurstmeister/kafka
3.2 拉取Kafka镜像
没写tag默认安装最新版本
docker pull wurstmeister/kafka
3.3 创建挂载目录
mkdir -p /home/kafka/{data,config}
3.4 启动Kafka镜像
docker run --privileged=true \
--log-driver json-file \
--log-opt max-size=100m \
--log-opt max-file=2 \
--name kafka -p 9092:9092 \
-e KAFKA_BROKER_ID=0 \
-e KAFKA_ZOOKEEPER_CONNECT=IP:2181/kafka \
-e KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://IP:9092 \
-e KAFKA_LISTENERS=PLAINTEXT://0.0.0.0:9092 \
-e ALLOW_PLAINTEXT_LISTENER=yes \
-e KAFKA_HEAP_OPTS='-Xms512M -Xmx4G' \
-v /home/kafka/data:/wurstmeister/kafka/data \
-v /home/kafka/config:/wurstmeister/kafka/config \
-v /etc/localtime:/etc/localtime \
-d wurstmeister/kafka
命令 注释
- --privileged=true 表示容器内的root拥有真正的root权限
- --log-driver json-file 表示使用 JSON 文件作为日志驱动
- --log-opt max-size=100m 表示设置日志的最大大小为100MB
- --log-opt max-file=2 表示设置日志文件的最大数量
- --name 表示容器命名
- -p 表示端口映射
- -e KAFKA_BROKER_ID=0 表示这个ID是集群的标识,不能重复
- -e KAFKA_ZOOKEEPER_CONNECT=IP:2181/kafka 表示zookeeper的连接地址
- -e KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://IP:9092 表示kafka发布到zookeeper供客户端使用的服务地址
- -e ALLOW_PLAINTEXT_LISTENER=yes 表示允许使用PLAINTEXT侦听器
- -e KAFKA_HEAP_OPTS='-Xms512M -Xmx4G 表示行内存参数
- -v /home/kafka/data:/wurstmeister/kafka/data 表示挂载配置数据目录
- -v /home/kafka/config:/wurstmeister/kafka/config 表示配置文件目录
- -v /etc/localtime:/etc/localtime 表示将本地时间映射到容器中
- -d 表示后台运行
配置目录,数据目录挂载我还没试过,谨慎使用!
3.5 查看Kafka容器是否运行
四、测试
4.1 通过exec命令进入容器内部
i :即使没有附加也保持STDIN 打开
t :分配一个伪终端
docker exec -it kafka /bin/bash
4.2 进入Kafka的bin目录下
cd /opt/kafka_2.13-2.8.1/bin
4.2 创建主题,显示主题
./kafka-topics.sh --create --topic test-kafka --bootstrap-server localhost:9092
kafka-topics.sh --describe --topic test-kafka --bootstrap-server localhost:9092
五、更多
Kafaka基础入门
测试成功
完成ヾ(◍°∇°◍)ノ゙
热门推荐
卷腹的动作怎么做
潮汕精华景点 潮汕旅游五天全攻略:潮汕五天四晚深度游路线攻略
海上“生绿电”,水下鱼满仓,广东是怎么做到的?
东吴策略:历史上的“四月决断”
70个实用做饭技巧,让你成为厨房达人!
观众到底渴望什么样的《三体》改编?
得了糖尿病,有哪些水果能吃?
广东工业大学第四轮学科评估结果排名
国产大飞机首航东北!东航C919首飞上海虹桥—沈阳航线
新生儿在医院照蓝光时死亡,专家呼吁规范治疗
房间颜色对孩子和孕妇的影响及选择原则
包装流程详解:从拣选到发货的完整指南
北京地铁新线开通:智慧运维系统助力运营安全高效
最强“质子刀”出鞘,“定向爆破”肿瘤细胞!28名受试者在协和医院开启质子治疗
茶叶储存全攻略:从容器选择到环境要求,一文详解如何保持茶叶新鲜
解锁创意潜能:AI生成的动态效果与艺术表达
现代艺术设计与传统工艺美术的融合
指甲剪不对,带来大麻烦!正确剪指甲应该这样做……
深入探究C++原子操作:原理、应用与性能权衡
收到“00”或“+”开头的电话要小心,赶快设置你的手机
印象派风景油画中的光与色:情感表达的艺术之道
勤加“练习”,让肠道畅游起来!
如何进行大客户需求管理
GPU算力池的构建与优化策略及其在人工智能应用中的重要性
生抽和老抽的区别:从原料到用途的全面解析
外贸邮件跟进:如何让客户从"已读"到"回复"
7个提升外贸邮件回复率的秘诀,让你的客户沟通更有效
家用健身器材选购全攻略:从需求到避坑的5大黄金法则
如何查看驱动情况数据库
强体 砺志 筑未来!《焦点访谈》报道各地学校体育教育经验