Kafka——消费者偏移量存储问题

2024-06-22 16:44

本文主要是介绍Kafka——消费者偏移量存储问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

引入—— 存储在哪

为啥最开始是存储在zookeeper中的?

为啥不继续用zookeeper存储了?

 回顾*分区副本机制


 

每个消费者在一个消费者组中都有自己的偏移量,用于记录消费到的消息位置。消费者可以通过提交偏移量来告知 Kafka 服务器它已经处理了哪些消息,下次消费时可以从哪里开始

 

引入—— 存储在哪

  • 较早的 Kafka 版本(0.8.x 及之前),消费者的偏移量是存储在 Zookeeper 中的。这种方式在新的 Kafka 版本中已经被弃用,因为将偏移量存储在 Kafka 自身可以提高性能并简化管理。
  • Kafka 0.9.0.0 版本开始,默认情况下,消费者组的偏移量会被存储在一个特殊的内部主题 `__consumer_offsets` 中。这个主题是由 Kafka 自动管理的,存储了所有消费者组的偏移量信息。
       - `__consumer_offsets` 主题使用与普通主题相同的*分区和副本机制,以保证偏移量存储的高可用性和可靠性。每个消费者组在每个分区中的偏移量都会被存储在这个主题的相应分区中。
  • 如何查看偏移量信息?
     Kafka 提供的命令行工具 kafka-consumer-groups.sh来查看和管理消费者组的偏移量。例如:
     
     
     kafka-consumer-groups.sh --bootstrap-server <kafka-broker> --describe --group <consumer-group-id>

为啥最开始是存储在zookeeper中的?

1.   Zookeeper 能确保每个消费者组中的偏移量信息一致且可靠。也避免了并发问题。

为啥zookeeper能确保每个消费者组的偏移量信息一致并且可靠?

s持久化存储数据不会丢失,原子性操作,保证了顺序性处理与应用,watch监视机制及时去通知

持久化存储:Zookeeper 将数据存储在磁盘上,即使发生服务器崩溃或重启,存储的偏移量信息也不会丢失。这种持久化存储保证了即使发生故障,也能够恢复正确的偏移量状态。

原子性操作:Zookeeper 支持原子性操作,这意味着针对单个 znode 的更新是原子的。

Watch 机制:Zookeeper 提供了一种监视机制,消费者可以通过注册 Watch 来监听偏移量信息的变化。一旦偏移量信息发生变化,Zookeeper 将通知订阅了该 Watch 的消费者,使得消费者能够及时更新自己的状态。

顺序一致性:确保了在多个操作同时发生时,每个操作都按照确定的顺序被处理和应用,避免了并发更新导致的数据不一致性问题。

只有leader进行写操作。follower进行读操作,这意味着,Zookeeper 都只会接受并传播来自 Leader 节点的更新,从而确保所有节点的数据视图是一致的。

 2. 

在 Kafka 早期版本中,架构设计简单,Zookeeper 被广泛用于集群的元数据管理,包括主题、分区、领导者选举等各种关键配置和状态。将消费者的偏移量存储在 Zookeeper 中是一个自然的选择。
3. 简单性

初期,使用 Zookeeper 来管理偏移量相对简单,开发和维护成本较低。Zookeeper 提供的 API 已经能够满足偏移量存储的基本需求。

为啥不继续用zookeeper存储了?

  • 1. 性能瓶颈

随着 Kafka 集群和消费者组规模的扩展,偏移量存储在 Zookeeper 中带来了性能瓶颈。频繁的读写操作增加了 Zookeeper 的负担,影响了整个系统的性能和可扩展性。

  • 2. 复杂性增加:

 管理依赖于 Zookeeper 的偏移量变得越来越复杂,特别是在大规模集群中。需要额外的运维和监控工作来确保 Zookeeper 的高可用性和性能。

  • 3. 延迟问题:

 Zookeeper 的一致性保证虽然强,但也会带来一定的延迟,特别是在网络不稳定或负载高的情况下。这对于需要快速响应的消费者来说,可能会影响实时性。

鉴于这些问题,Kafka 社区在 0.9.0.0 版本引入了将偏移量存储在 Kafka 自身的内部主题 `__consumer_offsets` 中的新机制。这种方式充分利用了 Kafka 的日志系统,解决了上述问题,带来了更好的性能、一致性和简化的管理方式。

总结来说,最开始将偏移量存储在 Zookeeper 中是基于当时的技术背景和架构设计考量,但随着 Kafka 的演进和应用场景的扩大,转向使用 Kafka 内部主题来存储偏移量是一个自然且必要的发展方向。

 回顾*分区副本机制

__consumer_offsets 主题,它存储了消费者组的偏移量信息,其分区和副本机制与普通主题类似,但有一些特殊性:

  • 分区数量__consumer_offsets 主题的分区数量通常等于 Kafka 集群中的 broker 数量,这样可以确保每个 broker 上都有该主题的分区副本。
  • 副本分布:与普通主题一样,__consumer_offsets 主题的每个分区会有多个副本分布在不同的 broker 上,确保数据的可靠性和容错性。
  • 选举和同步:如果某个副本不可用,Kafka 会通过副本的同步机制保证副本的数据与领导者副本保持同步,确保数据的完整性和一致性。

这篇关于Kafka——消费者偏移量存储问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1084844

相关文章

IDEA和GIT关于文件中LF和CRLF问题及解决

《IDEA和GIT关于文件中LF和CRLF问题及解决》文章总结:因IDEA默认使用CRLF换行符导致Shell脚本在Linux运行报错,需在编辑器和Git中统一为LF,通过调整Git的core.aut... 目录问题描述问题思考解决过程总结问题描述项目软件安装shell脚本上git仓库管理,但拉取后,上l

idea npm install很慢问题及解决(nodejs)

《ideanpminstall很慢问题及解决(nodejs)》npm安装速度慢可通过配置国内镜像源(如淘宝)、清理缓存及切换工具解决,建议设置全局镜像(npmconfigsetregistryht... 目录idea npm install很慢(nodejs)配置国内镜像源清理缓存总结idea npm in

pycharm跑python项目易出错的问题总结

《pycharm跑python项目易出错的问题总结》:本文主要介绍pycharm跑python项目易出错问题的相关资料,当你在PyCharm中运行Python程序时遇到报错,可以按照以下步骤进行排... 1. 一定不要在pycharm终端里面创建环境安装别人的项目子模块等,有可能出现的问题就是你不报错都安装

idea突然报错Malformed \uxxxx encoding问题及解决

《idea突然报错Malformeduxxxxencoding问题及解决》Maven项目在切换Git分支时报错,提示project元素为描述符根元素,解决方法:删除Maven仓库中的resolv... 目www.chinasem.cn录问题解决方式总结问题idea 上的 maven China编程项目突然报错,是

Python爬虫HTTPS使用requests,httpx,aiohttp实战中的证书异步等问题

《Python爬虫HTTPS使用requests,httpx,aiohttp实战中的证书异步等问题》在爬虫工程里,“HTTPS”是绕不开的话题,HTTPS为传输加密提供保护,同时也给爬虫带来证书校验、... 目录一、核心问题与优先级检查(先问三件事)二、基础示例:requests 与证书处理三、高并发选型:

前端导出Excel文件出现乱码或文件损坏问题的解决办法

《前端导出Excel文件出现乱码或文件损坏问题的解决办法》在现代网页应用程序中,前端有时需要与后端进行数据交互,包括下载文件,:本文主要介绍前端导出Excel文件出现乱码或文件损坏问题的解决办法,... 目录1. 检查后端返回的数据格式2. 前端正确处理二进制数据方案 1:直接下载(推荐)方案 2:手动构造

Python绘制TSP、VRP问题求解结果图全过程

《Python绘制TSP、VRP问题求解结果图全过程》本文介绍用Python绘制TSP和VRP问题的静态与动态结果图,静态图展示路径,动态图通过matplotlib.animation模块实现动画效果... 目录一、静态图二、动态图总结【代码】python绘制TSP、VRP问题求解结果图(包含静态图与动态图

MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决

《MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决》MyBatis默认开启一级缓存,同一事务中循环调用查询方法时会重复使用缓存数据,导致获取的序列主键值均为1,... 目录问题原因解决办法如果是存储过程总结问题myBATis有如下代码获取序列作为主键IdMappe

k8s搭建nfs共享存储实践

《k8s搭建nfs共享存储实践》本文介绍NFS服务端搭建与客户端配置,涵盖安装工具、目录设置及服务启动,随后讲解K8S中NFS动态存储部署,包括创建命名空间、ServiceAccount、RBAC权限... 目录1. NFS搭建1.1 部署NFS服务端1.1.1 下载nfs-utils和rpcbind1.1

Redis高性能Key-Value存储与缓存利器常见解决方案

《Redis高性能Key-Value存储与缓存利器常见解决方案》Redis是高性能内存Key-Value存储系统,支持丰富数据类型与持久化方案(RDB/AOF),本文给大家介绍Redis高性能Key-... 目录Redis:高性能Key-Value存储与缓存利器什么是Redis?为什么选择Redis?Red