Kafka 零基础实操命令大全

前面我们吃透了 Kafka 主题、分区、副本 的核心底层原理,理论落地必须依靠实操命令。Kafka 日常开发、测试、集群运维的核心操作,全部依赖自带的 shell 命令。

本文整理 全网最常用、最高频、零基础可直接复用 的 Kafka 命令,按「主题管理、消息生产消费、集群运维、分区副本、偏移量查询」分类,搭配详细参数解析、实操场景、避坑说明,新手直接复制即用,完美搭配上篇原理博文,做到懂原理、会实操

前置说明:本文命令基于 Kafka 2.x/3.x 新版本,统一使用 --bootstrap-server(废弃旧版 --zookeeper 方式),适配所有新版集群。

一、前置环境:基础连接地址

基于我们搭建的双节点 Kafka 集群,统一基础连接地址,所有命令通用:

172.17.0.7:9092

后续所有命令,只需替换对应主题名称即可直接执行。

二、核心高频:Topic 主题管理命令

主题是 Kafka 业务入口,主题的创建、查看、修改、删除是日常最高频操作,也是新手必掌握命令。

1. 创建主题(核心重点)

命令语法
kafka-topics.sh --create \ 
    --bootstrap-server 集群地址 \ 
    --topic 主题名 \ 
    --partitions 分区数 \ 
    --replication-factor 副本数
实操案例(生产常用配置)
kafka-topics.sh 
    --create 
    --bootstrap-server 172.17.0.7:9092 
    --topic test-topic 
    --partitions 3 
    --replication-factor 2
核心参数详解
  • --partitions:分区数,决定集群并发读写能力,只能增大不能减小

  • --replication-factor:副本数,硬性规则:副本数 ≤ 集群Broker节点数,否则创建失败

2. 查看所有主题

kafka-topics.sh --list --bootstrap-server 172.17.0.7:9092

作用:快速罗列集群中所有已创建的主题,排查主题是否存在、重复创建等问题。

3. 查看主题详细信息(分区/副本/Leader)

kafka-topics.sh --describe --topic test-topic --bootstrap-server 172.17.0.7:9092

实操核心作用:查看每个分区的 Leader 主节点、Follower 副本节点、ISR同步节点,验证分区副本分配是否均衡、集群是否正常。

字段解读

  • Leader:当前分区读写主节点

  • Replicas:所有副本存放节点

  • Isr:正常同步的副本节点(集群健康核心指标)

4. 修改主题分区(仅扩容,不可缩容)

# 将主题分区扩容为5个 
kafka-topics.sh 
    --alter 
    --topic test-topic 
    --partitions 5 
    --bootstrap-server 172.17.0.7:9092

重要避坑:Kafka 不支持减少分区数,只能新增扩容,分区缩减只能删除主题重建。

5. 删除主题

kafka-topics.sh --delete --topic test-topic --bootstrap-server 172.17.0.7:9092

注意:生产环境谨慎删除,删除后数据和元数据全部清空,无法恢复。

三、核心实操:消息生产与消费命令

创建主题后,必须掌握消息发送和消费命令,用于测试主题可用性、集群读写状态。

1. 控制台生产者(手动发送消息)

kafka-console-producer.sh --broker-list 172.17.0.7:9092 --topic test-topic

执行命令后,直接输入内容回车,即可向主题发送消息,适合快速测试。

示例输入:hello kafka、测试集群消息发送

2. 控制台消费者(监听消费消息)

基础消费(只消费新消息)
kafka-console-consumer.sh --bootstrap-server 172.17.0.7:9092 --topic test-topic
全量消费(从主题起始位置消费所有历史消息)
kafka-console-consumer.sh 
    --bootstrap-server 172.17.0.7:9092 
    --topic test-topic 
    --from-beginning

常用场景:排查历史消息、验证主题数据是否正常存储。

四、集群运维:状态查看常用命令

用于日常集群巡检、故障排查,快速确认 Broker 节点、集群运行状态。

1. 查看集群所有 Broker 节点

kafka-broker-api-versions.sh --bootstrap-server 172.17.0.7:9092

作用:查看集群在线 Broker 节点、版本信息,确认集群节点是否全部存活。

2. 查看集群主题总数

结合 wc -l 统计集群主题数量:

kafka-topics.sh --list --bootstrap-server 172.17.0.7:9092 | wc -l

3. 查看分区分布概况

kafka-topics.sh --describe --bootstrap-server 172.17.0.7:9092

不指定主题,默认查看集群所有主题的分区、副本、Leader 状态,适合全局巡检。

五、进阶常用:偏移量与消费组命令

消费组和偏移量是 Kafka 消息消费、断点续传的核心,是开发和面试高频重点。

1. 查看所有消费组

kafka-consumer-groups.sh --list --bootstrap-server 172.17.0.7:9092

2. 查看消费组详细状态(偏移量、堆积量)

kafka-consumer-groups.sh --describe --group 消费组名 --bootstrap-server 172.17.0.7:9092

核心字段

  • Current Offset:当前消费偏移量

  • Log End Offset:分区最大消息偏移量

  • Lag:消息堆积量(核心排查指标,Lag>0 代表有消息堆积)

3. 重置消费偏移量(运维常用)

# 重置偏移量,从头消费 
kafka-consumer-groups.sh 
 --reset-offsets
 --group 消费组名
 --topic test-topic 
 --to-earliest --execute 
 --bootstrap-server 172.17.0.7:9092 
# 重置偏移量,消费最新消息 
kafka-consumer-groups.sh 
    --reset-offsets --group 消费组名
    --topic test-topic 
    --to-latest 
    --execute --bootstrap-server 172.17.0.7:9092

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值