kafka 常用命令

1 集群操作

1.1 启动集群

  1. 在每个设备启动Zookeeper:

    bash 复制代码
    bin/zookeeper-server-start.sh config/zookeeper.properties

    若不想显示日志信息:

    shell 复制代码
    bin/zookeeper-server-start.sh config/zookeeper.properties > /dev/null 2>&1 &
  2. 在每个设备启动Kafka服务器:

    bash 复制代码
    bin/kafka-server-start.sh config/server.properties

    若不想显示日志信息:

    shell 复制代码
    bin/kafka-server-start.sh config/server.properties > /dev/null 2>&1 &

1.2 关闭集群

  1. 在每个设备关闭Kafka服务器:

    bash 复制代码
    bin/kafka-server-stop.sh
  2. 在每个设备关闭Zookeeper:

    bash 复制代码
    bin/zookeeper-server-stop.sh

1.3 检查Kafka状态

查看Kafka服务的状态可以使用kafka-broker-api-versions.sh

bash 复制代码
bin/kafka-broker-api-versions.sh --bootstrap-server localhost:9092

1.4 重新分配分区

重新分配分区通常用于扩展Kafka集群时,将主题的分区重新分配到新的broker上。使用以下步骤进行分区重新分配:

  1. 生成重新分配方案

    bash 复制代码
    bin/kafka-reassign-partitions.sh --generate --zookeeper localhost:2181 --topics-to-move-json-file topics-to-move.json --broker-list "0,1,2"
  2. 执行重新分配

    bash 复制代码
    bin/kafka-reassign-partitions.sh --execute --zookeeper localhost:2181 --reassignment-json-file reassignment.json
  3. 查看重新分配状态

    bash 复制代码
    bin/kafka-reassign-partitions.sh --verify --zookeeper localhost:2181 --reassignment-json-file reassignment.json

1.5 查看ZooKeeper中的Kafka数据

你可以使用ZooKeeper的命令行客户端zkCli.sh来查看Kafka在ZooKeeper中的数据:

bash 复制代码
bin/zookeeper-shell.sh localhost:2181

进入ZooKeeper shell后,可以使用以下命令:

  • 查看根节点:

    shell 复制代码
    ls /
  • 查看Kafka的brokers信息:

    shell 复制代码
    ls /brokers/ids
  • 查看某个节点的数据:

    shell 复制代码
    get /brokers/ids/0

2 主题操作

2.1 相关参数

  • --topic:指定主题的名称。
  • --bootstrap-server:Kafka broker的地址。
  • --replication-factor:副本因子,即每个主题分区的副本数。
  • --partitions:分区数。

2.2 创建主题

创建主题test-topic

bash 复制代码
bin/kafka-topics.sh --create --topic test-topic --bootstrap-server localhost:9092 --replication-factor 3 --partitions 2

2.3 查看主题

列出所有主题:

bash 复制代码
bin/kafka-topics.sh --list --bootstrap-server localhost:9092

描述主题test-topic的详细信息:

bash 复制代码
bin/kafka-topics.sh --describe --topic test-topic --bootstrap-server localhost:9092

2.4 删除主题

删除主题test-topic

bash 复制代码
bin/kafka-topics.sh --delete --topic test-topic --bootstrap-server localhost:9092

2.5 修改主题

修改主题test-topic

shell 复制代码
bin/kafka-topics.sh --alter --topic test-topic --bootstrap-server your-kafka-bootstrap-server:9092 --config max.message.bytes=10485760

3 生产与消费

3.1 生产消息

使用kafka-console-producer.sh发送消息到Kafka主题:

bash 复制代码
bin/kafka-console-producer.sh --topic test-topic --bootstrap-server localhost:9092

启动后可以输入消息并按回车发送。

3.2 消费消息

使用kafka-console-consumer.sh从Kafka主题消费消息:

bash 复制代码
bin/kafka-console-consumer.sh --topic test-topic --from-beginning --bootstrap-server localhost:9092

参数说明:

  • --from-beginning:表示从主题的开始位置消费消息。
相关推荐
白总Server5 分钟前
Nginx 中间件
大数据·linux·运维·服务器·nginx·bash·web
咨询1871506512731 分钟前
高企复审奖补!2025年合肥市高新技术企业重新认定奖励补贴政策及申报条件
大数据·人工智能·区块链
Guheyunyi43 分钟前
智能照明系统:照亮智慧生活的多重价值
大数据·前端·人工智能·物联网·信息可视化·生活
用户199701080181 小时前
深入解析淘宝商品详情 API 接口:功能、使用与实践指南
大数据·爬虫·数据挖掘
ONEYAC唯样1 小时前
“在中国,为中国” 英飞凌汽车业务正式发布中国本土化战略
大数据·人工智能
mozun20201 小时前
产业观察:哈工大机器人公司2025.4.22
大数据·人工智能·机器人·创业创新·哈尔滨·名校
Apache Flink2 小时前
京东物流基于Flink & StarRocks的湖仓建设实践
java·大数据·flink
董可伦2 小时前
Flink 源码编译
大数据·flink·源码
努力犯错2 小时前
昆仑万维开源SkyReels-V2,解锁无限时长电影级创作,总分83.9%登顶V-Bench榜单
大数据·人工智能·语言模型·开源
掘金-我是哪吒2 小时前
分布式微服务系统架构第119集:WebSocket监控服务内部原理和执行流程
分布式·websocket·微服务·架构·系统架构