Kafka高频面试题详解(consumer端)

1、消费者组和分区数之间的关系是怎样的?

消费者组内每个消费者负责消费不同分区的数据,一个分区只能由一个组内消费者消费

消费者组之间互不影响,所有的消费者都属于某个消费者组,即消费者组是逻辑上的一个订阅者

2、kafka如何知道哪个消费者消费哪个分区?

生产者把数据发送给各个分区,每个broker都有一个coordinator(协调器),消费者组对分区进行消费

GroupId对50取模,看最后的结果是哪个分区节点,假如是partition1,那么一分区的coordinator就是老大,消费者组中的消费者纷纷向coordinator发送JOinGroup请求,coordinator从中随机选一个consumer作为本次消费的Leader,coordinator把本次的消费情况发给Leader,让Leader制定一个消费计划(哪个consumer消费哪个partition)并发给coordinator,协调器再进行群发并公布给各个consumer,各个consumer按照这个计划进行消费

3、kafka消费者的消费分区策略有哪些,默认是个?

Kafka有四种主流的分区分配策略: Range、RoundRobin(轮询)、Sticky(粘性)、CooperativeSticky(配合的粘性)

可以通过配置参数partition.assignment.strategy,修改分区的分配策略。默认策略是Range + CooperativeSticky。Kafka可以同时使用多个分区分配策略。

3.1 Range分区策略原理

3.2 RoundRobin 分区策略原理

7.3 Sticky 分区策略原理

**粘性分区定义:**可以理解为分配的结果带有"粘性的"。即在执行一次新的分配之前, 考虑上一次分配的结果,尽量少的调整分配的变动,可以节省大量的开销。 粘性分区是 Kafka 从 0.11.x 版本开始引入这种分配策略,首先会尽量均衡的放置分区 到消费者上面,在出现同一消费者组内消费者出现问题的时候,会尽量保持原有分配的分区不变化
使用粘性分区会按照上一次的分区方法进行分区

7.4 CooperativeSticky

在消费过程中,会根据消费的偏移量情况进行重新再平衡,也就是粘性分区,运行过程中还会根据消费的实际情况重新分配消费者,直到平衡为止。

好处是:负载均衡,不好的地方是:多次平衡浪费性能。

动态平衡,在消费过程中,实施再平衡,而不是定下来,等某个消费者退出再平衡。

相关推荐
沐浴露z1 小时前
Kafka Consumer 消费流程详解
java·分布式·kafka
starandsea1 小时前
kafka添加压缩配置后失败
分布式·kafka·linq
Lemon程序馆3 小时前
Kafka | Broker 工作原理
后端·kafka·消息队列
不开心就吐槽10 小时前
linux安装kafka
linux·运维·kafka
飞鱼&10 小时前
Kafka(文件)数据存储、清理机制、高性能设计
分布式·kafka
2301_8035545210 小时前
c++调用客户端库与kafka交互
c++·kafka·交互
观望过往1 天前
Kafka 全方位详细介绍:从架构原理到实践优化
分布式·架构·kafka
菜鸡儿齐2 天前
kafka简介
分布式·kafka
深兰科技2 天前
深兰科技入选“2025中国人工智能行业创新力企业百强”
人工智能·科技·百度·kafka·rabbitmq·memcached·深兰科技
Hello World......2 天前
互联网大厂Java面试实战:以Spring Boot与微服务为核心的技术场景剖析
java·spring boot·redis·微服务·junit·kafka·spring security