windows系统搭建kafka环境

kafka内置zk,因此没必要安装zk。

kafka.apache.org/community/d...

1.修改zookeeper.properties文件

js 复制代码
dataDir=E:/kafka_2.12-3.6.1/data/zk

2.修改server.properties文件

js 复制代码
log.dirs=e:/kafka/data/kafka

3.配置zk.cmd

js 复制代码
call bin/windows/kafka-server-start.bat config/server.properties

4.配置kafka.cmd

js 复制代码
call bin/windows/zookeeper-server-start.bat config/zookeeper.properties

5.一些常用的命令

js 复制代码
kafka-topics.bat 相关

 --bootstrap-server : 把当前的DOS窗口当成Kafka的客户端
 --create : 表示对主题的创建操作,是个操作参数,后面无需增加参数值
 --topic : 主题的名称
 --list : 表示对所有主题的查询操作,是个操作参数,后面无需增加参数值
 --describe : 查看主题的详细信息
 --alter : 表示对所有主题的查询操作,是个操作参数,后面无需增加参数值
--partitions : 修改的配置参数:分区数量
 --delete: 表示对主题的删除操作,是个操作参数,后面无需增加参数值。默认情况下,删除操作是逻辑删除,也就是说数据存储的文件依然存在,
但是通过指令查询不出来。如果想要直接删除,需要在server.properties文件中设置参数delete.topic.enable=true

kafka-topics.bat --bootstrap-server localhost:9092 --create --topic test
kafka-topics.bat --bootstrap-server localhost:9092 --list
kafka-topics.bat --bootstrap-server localhost:9092 --describe --topic test
kafka-topics.bat --bootstrap-server localhost:9092 --topic test --alter --partitions 2
kafka-topics.bat --bootstrap-server localhost:9092 --topic test --delete

notice:
windows系统中由于权限或进程锁定的问题,删除topic会导致kafka服务节点异常关闭。

kafka-console-producer.bat 相关

kafka-console-producer.bat --bootstrap-server localhost:9092 --topic test

typing message you want to send

kafka-console-consumer.bat 相关

--from-beginning : 从第一条数据开始消费,无参数值,是一个标记参数

kafka-console-consumer.bat --bootstrap-server localhost:9092 --topic test --from-beginning

6.windows端模拟集群服务的搭建

js 复制代码
解压kafka_2.12-3.6.1.tgz 分别生成4个文件夹 node-1,node-2,node-3,zookeeper


node-1 修改server.properties
broker.id=1
listeners=PLAINTEXT://:9091 log.dirs=E:/kafka/node-1/data zookeeper.connect=localhost:2181/kafka

node-2 修改server.properties 
broker.id=2 
listeners=PLAINTEXT://:9092 log.dirs=E:/kafka/node-2/data zookeeper.connect=localhost:2181/kafka

node-3 修改server.properties
broker.id=3 
listeners=PLAINTEXT://:9093 log.dirs=E:/kafka/node-3/data zookeeper.connect=localhost:2181/kafka


zookeeper文件夹添加zk.cmd
zk.cmd内容:
call bin/windows/zookeeper-server-start.bat config/zookeeper.properties



node-1 node-2 node-3 添加kafka.cmd
kafka.cmd内容:
call bin/windows/kafka-server-start.bat config/server.properties

node-1 同级别路径添加cluster.cmd cluster-clear.cmd

7.cluster.cmd

js 复制代码
cd zookeeper
start zk.cmd
ping 127.0.0.1 -n 10 >nul
cd ../node-1
start kafka.cmd
cd ../node-2
start kafka.cmd
cd ../node-3
start kafka.cmd

8.cluster-clear.cmd

js 复制代码
cd zookeeper
rd /s /q data
cd ../node-1
rd /s /q data
cd ../node-2
rd /s /q data
cd ../node-3
rd /s /q data
相关推荐
leobertlan3 小时前
2025年终总结
前端·后端·程序员
面向Google编程3 小时前
从零学习Kafka:数据存储
后端·kafka
易安说AI4 小时前
Claude Opus 4.6 凌晨发布,我体验了一整晚,说说真实感受。
后端
易安说AI4 小时前
Ralph Loop 让Claude无止尽干活的牛马...
前端·后端
易安说AI4 小时前
用 Claude Code 远程分析生产日志,追踪 Claude Max 账户被封原因
后端
颜酱5 小时前
图结构完全解析:从基础概念到遍历实现
javascript·后端·算法
Coder_Boy_7 小时前
基于SpringAI的在线考试系统-考试系统开发流程案例
java·数据库·人工智能·spring boot·后端
掘金者阿豪8 小时前
关系数据库迁移的“暗礁”:金仓数据库如何规避数据完整性与一致性风险
后端
ServBay9 小时前
一个下午,一台电脑,终结你 90% 的 Symfony 重复劳动
后端·php·symfony
sino爱学习9 小时前
高性能线程池实践:Dubbo EagerThreadPool 设计与应用
java·后端