Kafka日常运维命令总结

一、集群管理
  1. 前台启动Broker

    bash 复制代码
    bin/kafka-server-start.sh <path>/server.properties
    • 关闭方式:Ctrl + C
  2. 后台启动Broker

    bash 复制代码
    bin/kafka-server-start.sh -daemon <path>/server.properties
  3. 关闭Broker

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

二、Topic管理
操作 命令
创建Topic bin/kafka-topics.sh --create --bootstrap-server localhost:9092 --partitions 3 --replication-factor 3 --topic <topicname>
删除Topic bin/kafka-topics.sh --delete --bootstrap-server localhost:9092 --topic <topicname>
查询Topic列表 bin/kafka-topics.sh --bootstrap-server localhost:9092 --list
查询Topic详情 bin/kafka-topics.sh --bootstrap-server localhost:9092 --describe --topic <topicname>
增加分区数 bin/kafka-topics.sh --alter --bootstrap-server localhost:9092 --partitions 6 --topic <topicname>

注意 :新版本推荐使用--bootstrap-server替代--zookeeper


三、Consumer Groups管理
操作 命令
查询消费组列表 bin/kafka-consumer-groups.sh --bootstrap-server localhost:9092 --list
查询消费组详情 bin/kafka-consumer-groups.sh --bootstrap-server localhost:9092 --describe --group <groupname>
删除消费组 bin/kafka-consumer-groups.sh --bootstrap-server localhost:9092 --delete --group <groupname>
  1. 重设消费位移

    bash 复制代码
    # 重置到最早位移
    bin/kafka-consumer-groups.sh --bootstrap-server localhost:9092 --group <groupname> --reset-offsets --to-earliest --execute
    
    # 重置到最新位移
    bin/kafka-consumer-groups.sh --bootstrap-server localhost:9092 --group <groupname> --reset-offsets --to-latest --execute
    
    # 重置到指定位移
    bin/kafka-consumer-groups.sh --bootstrap-server localhost:9092 --group <groupname> --reset-offsets --to-offset 2000 --execute

四、常用运维工具
  1. 生产者控制台

    bash 复制代码
    bin/kafka-console-producer.sh --broker-list localhost:9092 --topic <topicname>
    • 高级参数:
      --compression-codec lz4(压缩)
      --request-required-acks all(ACK机制)
      --message-send-max-retries 10(重试次数)
  2. 消费者控制台

    bash 复制代码
    bin/kafka-console-consumer.sh --bootstrap-server localhost:9092 --topic <topicname> --group <groupname> --from-beginning
  3. 性能测试工具

    bash 复制代码
    # 生产者性能测试
    bin/kafka-producer-perf-test.sh --topic <topic> --num-records 1000000 --record-size 1000
    
    # 消费者性能测试
    bin/kafka-consumer-perf-test.sh --topic <topic> --messages 1000000
  4. 获取Topic消息数

    bash 复制代码
    # 最新位移(总消息数)
    bin/kafka-run-class.sh kafka.tools.GetOffsetShell --broker-list localhost:9092 --topic <topic> --time -1
    
    # 最早位移
    bin/kafka-run-class.sh kafka.tools.GetOffsetShell --broker-list localhost:9092 --topic <topic> --time -2

五、分区管理
  1. Preferred Leader选举

    bash 复制代码
    bin/kafka-leader-election.sh --bootstrap-server localhost:9092 --election-type preferred --topic <topic> --partition 0
  2. 分区重分配

    bash 复制代码
    # 生成迁移计划
    bin/kafka-reassign-partitions.sh --bootstrap-server localhost:9092 --generate --topics-to-move-json-file plan.json
    
    # 执行迁移
    bin/kafka-reassign-partitions.sh --bootstrap-server localhost:9092 --execute --reassignment-json-file reassign.json
    
    # 验证进度
    bin/kafka-reassign-partitions.sh --bootstrap-server localhost:9092 --verify --reassignment-json-file reassign.json

六、高级运维
  1. 查看日志段元数据

    bash 复制代码
    bin/kafka-dump-log.sh --files 000000000000.log --print-data-log
  2. 跨集群复制(MirrorMaker)

    bash 复制代码
    bin/kafka-mirror-maker.sh --consumer.config consumer.conf --producer.config producer.conf --whitelist ".*"
  3. 查看__consumer_offsets

    bash 复制代码
    bin/kafka-console-consumer.sh --topic __consumer_offsets --formatter "kafka.coordinator.group.GroupMetadataManager\$OffsetsMessageFormatter"

关键注意事项:

  1. 版本兼容性

    • ≥ Kafka 2.2.x 推荐使用 --bootstrap-server 替代 --zookeeper
    • 删除Topic需确保 delete.topic.enable=true
  2. 生产环境建议

    • 分区重分配避免高峰时段操作
    • 重设位移前先停止消费者组
    • MirrorMaker需监控复制延迟
  3. 常用诊断技巧

    bash 复制代码
    # 检查消息积压(Lag)
    bin/kafka-consumer-groups.sh --describe --group <group> | awk '{print $6}'
    
    # 检查Controller状态
    bin/kafka-metadata-quorum.sh --status

完整文档参考:Apache Kafka Operations

相关推荐
翼龙云_cloud11 小时前
阿里云代理商:部署 DeepSeek V4-Flash解析 快速部署与性能优化
运维·阿里云·性能优化·云计算·ai智能体
正经教主11 小时前
【docker基础】 第七课:Docker Compose 多容器实战
运维·docker·容器
ElevenS_it18811 小时前
网络设备配置合规审计自动化实战:用Nornir+Netmiko自动比对华为/Cisco/H3C配置基线+合规报告自动生成
运维·网络·自动化
施努卡机器视觉11 小时前
SNK施努卡 | 电子油泵自动化生产线:精密制造的技术跃迁与产业价值
运维·自动化·制造
ShyanZh11 小时前
【skill】Agent-Browser:AI代理的浏览器自动化实战指南
运维·人工智能·自动化·skill·agent-browser
KKKlucifer11 小时前
智能研判、本地运算、一键运维:新一代安全管控产品的三大核心能力
运维·安全
MXsoft61811 小时前
##务健康度评分:将运维指标转化为业务价值的实践指南
运维
闪电悠米11 小时前
黑马点评-Redis 消息队列-04_stream_seckill_order
数据库·redis·分布式·缓存·oracle·junit·lua
難釋懷11 小时前
Nginx使用sticky模块完成对Nginx的负载均衡
运维·nginx·负载均衡
HLAIA光子11 小时前
分布式锁与事务:你的微服务可能根本不需要它们
分布式·后端·微服务