900字范文,内容丰富有趣,生活中的好帮手!
900字范文 > kafka 基础概念 命令行操作(查看所有topic 创建topic 删除topic 查看某个Topic

kafka 基础概念 命令行操作(查看所有topic 创建topic 删除topic 查看某个Topic

时间:2022-05-26 22:58:39

相关推荐

kafka 基础概念 命令行操作(查看所有topic 创建topic 删除topic 查看某个Topic

文章目录

前言1. 基础概念BrokerProducerConsumerConsumer GroupTopicPartitionReplica 2. 命令行操作2.1 查看所有topic2.2 创建topic2.3 删除topic2.4 查看某个Topic的详情2.5 修改分区数2.6 发送消息2.7 消费消息2.8 查看消费者组2.9 更新消费者的偏移位置

前言

kafka官网

1. 基础概念

Broker

一台kafka服务器就是一个broker,可容纳多个topic。一个集群由多个broker组成;

Producer

生产者,即向kafka的broker-list发送消息的客户端;

Consumer

消费者,即向kafka的broker-list订阅消息的客户端;

Consumer Group

消费者组是逻辑上的一个订阅者,由多个consumer组成。消费者组内每个消费者负责消费不同分区的数据,一个分区只能由一个组内消费者消费;所有的消费者都属于某个消费者组,消费者组之间互不影响;

Topic

可理解为一个队列,生产者和消费者均面向一个topic;

Partition

一个topic可以分为多个partition,每个partition是一个有序的队列;这使得一个topic可分布到多个broker(即服务器)上,

Replica

副本,kafka提供了副本机制,一个topic的每个分区都有若干个副本,即一个leader和若干个follower,从而保证集群单点故障时节点上的partition数据不丢失

leader:每个分区多个副本的生产者发送数据的对象,以及消费者消费数据的对象都是leader

follower:实时从leader中同步数据,保持和leader数据的同步。leader发生故障时,某个follower会成为新的leader

2. 命令行操作

2.1 查看所有topic

./kafka-topics.sh --bootstrap-server 192.168.0.23:29092,192.168.0.114:29092,192.168.0.110:29092 --list

2.2 创建topic

./kafka-topics.sh --bootstrap-server 192.168.0.23:29092,192.168.0.110:29092 --create --replication-factor 3 --partitions 3 --topic charges

--topic定义topic名

--replication-factor定义副本数

--partitions定义分区数

2.3 删除topic

./kafka-topics.sh --bootstrap-server 192.168.0.23:29092,192.168.0.114:29092,192.168.0.110:29092 --delete --topic charges

2.4 查看某个Topic的详情

./kafka-topics.sh --bootstrap-server 192.168.0.23:29092,192.168.0.114:29092,192.168.0.110:29092 --describe --topic charges

2.5 修改分区数

./kafka-topics.sh --bootstrap-server 192.168.0.23:29092,192.168.0.114:29092,192.168.0.110:29092 --alter --partitions 6 --topic charges

2.6 发送消息

./kafka-console-producer.sh --broker-list 192.168.0.23:29092,192.168.0.114:29092,192.168.0.110:29092 --topic charges

2.7 消费消息

./kafka-console-consumer.sh --bootstrap-server 192.168.0.23:29092,192.168.0.114:29092,192.168.0.110:29092 --from-beginning --topic charges --group htsc

--from-beginning:若消费者没有offset,则从the earliest message present in the log而非默认的the latest message

--group: 指定消费者所属的消费者组

注:默认情况下,若zookeeper或__consumer_offsets中有offset记录,则Kafka消费者从最后一次提交的偏移量位置(offset)开始消费消息。若之前没有提交过偏移量,则消费消息开始位置取决于Topic的配置属性auto.offset.reset的设置,默认为最新(latest 仅消费新消息

2.8 查看消费者组

./kafka-consumer-groups.sh --bootstrap-server 192.168.0.23:29092,192.168.0.114:29092,192.168.0.110:29092 --list

./kafka-consumer-groups.sh --bootstrap-server 192.168.0.23:29092,192.168.0.114:29092,192.168.0.110:29092 --describe --group htsc

注: 通过查看消费者组,可查看到topic所有分区当前的偏移量以及LOG-END-OFFSET(最后的偏移量),即消费消息的现状

2.9 更新消费者的偏移位置

将topic charges对应的消费组htsc 的分区编号0的偏移量设置为最早

./kafka-consumer-groups.sh --bootstrap-server 192.168.0.23:29092,192.168.0.114:29092,192.168.0.110:29092 --topic charges:0 --group htsc --reset-offsets --to-earliest --execute

--reset-offsetsReset offsets of consumer group

--to-earliestReset offsets to earliest offset

--to-latestReset offsets to latest offset.

--to-offset <Long: offset>Reset offsets to a specific offset

kafka 基础概念 命令行操作(查看所有topic 创建topic 删除topic 查看某个Topic的详情 修改分区数 发送消息 消费消息 查看消费者组 更新消费者的偏移位置)

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。