基于Docker以KRaft模式快速部署Kafka

参考文献

https://kafka.apache.org/37/documentation.html#uses

https://spring.io/projects/spring-kafka#overview


获取Docker镜像

复制代码
docker pull apache/kafka:3.7.1

创建一个目录来存储Kafka的配置文件

复制代码
mkdir -p /home/user/kafka_config

启动Kafka容器

复制代码
docker run -d \
   --name kira-kafka \
   -v /home/user/kafka_config:/opt/kafka/config \
   -p 9092:9092 \
   --user root \
   apache/kafka:3.7.1

cd /var/lib/docker/volumes/kafka_data/_data

创建Kafka的主题

进入Kafka容器

复制代码
docker exec -u root -it kira-kafka bash

找到kafka-topics.sh:在容器中查找脚本路径

复制代码
find / -name kafka-topics.sh

创建主题:根据实际的路径,运行命令

复制代码
/opt/kafka/bin/kafka-topics.sh --create --topic quickstart-events --bootstrap-server localhost:9092

查看主题

复制代码
/opt/kafka/bin/kafka-topics.sh --describe --topic quickstart-events --bootstrap-server localhost:9092

然后用kafka-King可视化工具进行连接

进入容器内部改成正确的IP(如果内部IP不正确时)

复制代码
docker exec -u root -it kira-kafka bash

编辑文件

复制代码
vi /opt/kafka/config/server.properties

删除localhost

esc

:wq保存

删除这个

保留这一行,改成我们的虚拟机本机地址而不是localhost

复制代码
listeners=PLAINTEXT://0.0.0.0:9092
advertised.listeners=PLAINTEXT://192.168.88.130:9092

退出容器

重启kafka容器

检查本地挂载目录权限保证它可写

复制代码
ls -ld /home/user/kafka_config

如果目录权限修改不正确,可以使用以下命令修改权限

复制代码
sudo chown -R 1000:1000 /home/user/kafka_config
sudo chmod -R 755 /home/user/kafka_config

修改容器内权限

复制代码
docker exec -u root -it kira-kafka bash
chmod -R 777 /opt/kafka/config

重启容器

复制代码
docker restart kira-kafka

如何验证挂载

进入容器内部

复制代码
docker exec -it kira-kafka bash

检查挂载目录

复制代码
ls /opt/kafka/config
相关推荐
兰令水2 分钟前
leecodecode【反前后指针】【2026.5.31打卡-java版本】
java·开发语言
草莓熊Lotso1 小时前
【Linux网络】深入理解 HTTP 协议(二):从协议格式到手写工业级 HTTP 服务器
linux·运维·服务器·网络·c++·http
上海云盾第一敬业销售2 小时前
服务器遭受攻击的应对策略及快速防护实践
运维·服务器·web安全·ddos
剑神一笑7 小时前
Linux pgrep 命令详解:按名称查找进程 PID 的高效方法
linux·运维·chrome
Lumbrologist7 小时前
【零基础部署】Docker 部署 CrewAI 多 Agent 编排框架保姆级教程
运维·docker·容器
AI人工智能+电脑小能手8 小时前
【大白话说Java面试题 第87题】【Mysql篇】第17题:分布式事务的实现原理?
java·数据库·分布式·mysql·面试
yyuuuzz8 小时前
独立站的技术基础与常见运维问题
大数据·运维·服务器·网络·数据库·aws
剑神一笑8 小时前
Linux killall 命令详解:按进程名批量终止进程的原理与实践
linux·运维·chrome
雅菲奥朗8 小时前
企业级 AI 自动化|OpenClaw 龙虾实战与认证
运维·人工智能·自动化·openclaw
来杯@Java8 小时前
图书管理系统(基于springboot+vue前后端分离的项目)计算机毕业设计java
java·spring boot·spring·vue·毕业设计·mybatis·课程设计