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基础入门
测试成功
完成ヾ(◍°∇°◍)ノ゙
热门推荐
发轫和滥觞:两个表示开端的词语有何区别?
山西焦煤集团:瓦斯综合利用助力零碳矿山建设
全面指南:如何精准评估玉镯成色与价值,鉴别真假与优劣
春季嗓子不适别大意,可能是这种“凶险”急症!可致急性窒息!
祁县全域旅游新篇章,融合晋商茶商湿地玻璃艺术
朴正熙为什么叫卡卡:背后的文化渊源与演变
精神分裂症除了吃药,还可以打针 ——长效针你了解吗?
如何查近期热点数据库
长平之战:战略的巅峰,历史的教训
如何灵活调整你的股票策略:灵活调整股票策略的方法?
CRO,探讨数字化转型的新趋势
伺服电机控制伺服电机案例程序整套伺服电机PLC程
抗战时期我国五家飞机制造厂:从组装到自主研发的艰难历程
二维码扫描器的应用场景及工作原理
如何正确计算房产交易税费?这种税费如何合理规划?
评判思维:一种认知与决策方式
生白术食疗全解析:美味食谱+功效+小心机!
泰捷盒子刷机教程:让你的泰捷盒子焕然一新,畅享更多功能
圣经旧约与新约:信仰之典的两面
宣汉全景旅游指南:热门景点、隐藏秘境、美食住宿一网打尽
昆明一日游的最佳攻略
山竹的喜阳还是喜阴?(探究山竹的光照需求与种植技巧)
金庸笔下郭靖之名含深意 记录靖康耻与靖康钱
铁血忠魂:岳飞与岳家军的不朽传说
铁建“变轨”,央企抛弃新能源又增一员?
活血化瘀:下医用桃红四物汤,中医选血府逐瘀汤,上医开抵挡汤!
巴菲特久赌必赢的投资秘笈——凯利公式
为何连续用电子血压计测量,血压的结果却不一致? 如何测最准确
真正四季开花的十大藤本月季
女人吃补中益气丸好吗?补中益气丸的13种用途详解