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

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

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

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

相关推荐
打工的小王12 小时前
消息队列之Kafka(一)搭建服务
分布式·kafka
DemonAvenger14 小时前
Kafka高可用设计揭秘:副本机制与选举策略的实践之道
性能优化·kafka·消息队列
Jack_David15 小时前
kafka_2.13-4.1.1集群安装
java·分布式·kafka
愿你天黑有灯下雨有伞15 小时前
Spring Boot 整合 Kafka:生产环境标准配置与最佳实践
java·kafka
jiuweiC17 小时前
kafka重平衡问题-golang
分布式·golang·kafka
你这个代码我看不懂1 天前
@RefreshScope刷新Kafka实例
分布式·kafka·linq
indexsunny1 天前
互联网大厂Java面试实战:Spring Boot到Kafka的技术问答解析
java·spring boot·redis·junit·kafka·spring security·microservices
若鱼19192 天前
SpringBoot4.0集成Kafka4-收发POJO消息
java·spring·kafka
中国胖子风清扬2 天前
Rust 桌面应用开发的现代化 UI 组件库
java·后端·spring·ui·rust·kafka·web application
DemonAvenger2 天前
深入剖析Kafka存储原理:日志文件结构与索引机制解析
性能优化·kafka·消息队列