Kafka 环境配置与使用总结

复制代码
# 部署教程参考 # 官方教程: https://kafka.apache.org/quickstart 
# 单机部署kafka参考: https://blog.csdn.net/u013416034/article/details/123875299 
# 集群部署kafka参考: 
# https://blog.csdn.net/zhangzjx/article/details/123679453 
# https://www.cnblogs.com/Andrew-Zhou/p/15366574.html

1-服务启动

bash 复制代码
# 服务启动
./bin/kafka-server-stop.sh
./bin/zookeeper-server-stop.sh

./bin/zookeeper-server-start.sh ./config/zookeeper.properties
./bin/kafka-server-start.sh ./config/server.properties

2-主题topic操作

bash 复制代码
./bin/kafka-topics.sh --list --bootstrap-server ip:9002  #topic列表
./bin/kafka-topics.sh --describe --bootstrap-server ip:9002  --topic topic_name #查看某topic信息
./bin/kafka-topics.sh --create --bootstrap-server ip:9002 --replication-factor 1 --partition 1 --topic topic_name #创建某topic
./bin/kafka-topics.sh --delete --bootstrap-server ip:9002 --topic topic_name #删除某topic
./bin/kafka-run-class.sh kafka.tools.GetOffsetShell --broker-list ip:9092 --topic topic_name --time-1 #查看消息数量
# 查看某个分区下的消息总量
./bin/kafka-run-class.sh kafka.tools.GetOffsetShell --broker-list ip:9092 --topic topic_name --partition 0

3-消费者组操作

bash 复制代码
./bin/kafka-consumer-groups.sh --list --bootstrap-server ip:9092 #所有消费者组列表
./bin/kafka-consumer-groups.sh --describe --state --all-groups --bootstrap-server ip:9092 #所有消费者组状态
./bin/kafka-consumer-groups.sh --describe --all-groups --members --bootstrap-server ip:9092 #所有消费者组成员
./bin/kafka-consumer-groups.sh --describe --state --group group_name --bootstrap-server ip:9092 #指定消费者组状态
./bin/kafka-consumer-groups.sh --describe --group group_name --bootstrap-server ip:9092 #指定消费者组详情
./bin/kafka-consumer-groups.sh --delete --group group_name --bootstrap-server ip:9092 #删除指定消费者组
./bin/kafka-consumer-groups.sh --execute --reset-offsets --to-latest --group group_name --bootstrap-server ip:9092 #创建消费者组
# 查看某个用户组的消息积压情况
./bin/kafka-consumer-groups.sh --describe --bootstrap-server ip:9092 --group group_name #所有消费者组状态
# 注意:LAG为积压的消息数量,Current-Offset、Log-Offset分别为当前offset以及总的Offset

4-Console操作

bash 复制代码
./bin/kafka-console-consumer.sh --bootstrap-server ip:9092  --topic topic_name --from-beginning #打印指定topic的内容
./bin/kafka-console-consumer.sh --bootstrap-server ip:9092  --topic topic_name --from-beginning | grep "**" #打印指定topic的内容
./bin/kafka-console-producer.sh --bootstrap-server ip:9092  --topic topic_name #生产消息

5-Configs操作

bash 复制代码
./bin/kafka-configs.sh --bootstrap-server ip:9092 --describe --entity-type topics --entity-type topic_name #查看topic数据清理策略
./bin/kafka-configs.sh --bootstrap-server ip:9092 --entity-type topics --entity-type topic_name --alter --add-config retention.ms=1000 #修改topic数据清理策略
# 注意:修改保留时间为1000ms,但不是修改后1000ms就马上删除,kafka采用轮训的方式,轮训到该topic发现是1000ms前的数据就删掉
./bin/kafka-configs.sh --bootstrap-server ip:9092 --entity-type topics --entity-type topic_name --alter --config cleanup.policy=delete #修改topic数据清理策略为立即删除
./bin/kafka-configs.sh --bootstrap-server ip:9092 --entity-type topics --entity-type topic_name --alter --add-config partitions=3

6-【不同服务器间的消费配置】

bash 复制代码
listeners=PLAINTEXT://IP:9092  # vim config/server.properties
相关推荐
我爱娃哈哈22 分钟前
SpringBoot + Seata + Nacos:分布式事务落地实战,订单-库存一致性全解析
spring boot·分布式·后端
掘金-我是哪吒2 小时前
Kafka配套的Zookeeper启动脚本
分布式·zookeeper·云原生·kafka
超级种码2 小时前
Kafka四部曲之一:Kafka的核心概念
分布式·kafka
Java 码农3 小时前
RabbitMQ集群部署方案及配置指南09
分布式·rabbitmq
u0104058363 小时前
基于 Kafka Exactly-Once 语义保障微信群发消息不重复不丢失
分布式·kafka·linq
超级种码4 小时前
Kafka四部曲之二:核心架构与设计深度解析
分布式·架构·kafka
optimistic_chen4 小时前
【Redis 系列】持久化特性
linux·数据库·redis·分布式·中间件·持久化
论迹4 小时前
RabbitMQ
分布式·rabbitmq
Java 码农4 小时前
RabbitMQ集群部署方案及配置指南08--电商业务延迟队列定制化方案
大数据·分布式·rabbitmq
CodeAmaz4 小时前
分布式 ID 方案(详细版)
分布式·分布式id