当前位置: 首页 > news >正文

【kafka系列】broker

目录

Broker 接收生产者消息和返回消息给消费者的流程逻辑分析

Broker 处理生产者消息的核心流程

Broker 处理消费者消息的核心流程

关键点总结


Broker 接收生产者消息和返回消息给消费者的流程逻辑分析


Broker 处理生产者消息的核心流程
  1. 接收请求
    • Broker 的 SocketServer 接收来自生产者的 ProduceRequest(基于 Reactor 网络模型)。
  1. 请求解析与验证
    • 解析请求头(Topic、Partition、消息数据)。
    • 验证 Topic 是否存在、生产者是否有写入权限(ACL/SASL)。
  1. 定位 Leader 副本
    • 根据 Partition ID 找到对应的 Leader 副本(元数据存储在内存或 KRaft/ZooKeeper)。
  1. 写入日志文件
    • 消息以顺序追加方式写入 Leader 副本的 Log 文件(.log),并更新索引文件(.index)。
  1. 副本同步(ISR 机制)
    • Leader 将消息推送给 ISR(In-Sync Replicas)列表中的 Follower 副本。
    • 若 Follower 副本同步超时(replica.lag.time.max.ms),会被移出 ISR。
  1. 响应生产者
    • 根据 acks 配置返回响应:
      • acks=0:不等待确认,直接返回成功。
      • acks=1:等待 Leader 写入完成。
      • acks=all:等待所有 ISR 副本确认。

设计思想

  • 高吞吐:顺序 I/O + 页缓存(Page Cache)优化写入性能。
  • 可靠性:ISR 机制保证数据冗余,避免单点故障。

Broker 处理消费者消息的核心流程
  1. 接收请求
    • Broker 的 SocketServer 接收消费者的 FetchRequest(指定 Topic、Partition、Offset)。
  1. 请求解析与验证
    • 验证消费者权限、Offset 有效性(是否在 Log 的保留范围内)。
  1. 定位 Leader 副本
    • 确认消费者请求的 Partition Leader 副本所在 Broker(若当前 Broker 不是 Leader,返回错误)。
  1. 读取日志文件
    • 根据 Offset 从 Log 文件中定位消息位置,利用索引文件(.index)快速查找。
  1. 零拷贝发送
    • 使用 sendfile 系统调用,直接从页缓存(Page Cache)发送数据到网络,避免用户态内存拷贝。
  1. 返回响应
    • 封装消息数据到 FetchResponse,包含实际 Offset、消息内容及元数据。

设计思想

  • 低延迟:零拷贝技术减少 CPU 和内存开销。
  • 高效读取:稀疏索引(Sparse Index)快速定位消息位置。


关键点总结

  1. 生产者写入
    • 强依赖 Leader 副本和 ISR 机制保障数据一致性。
    • acks 配置直接影响可靠性和延迟。
  1. 消费者读取
    • 零拷贝技术是 Kafka 高吞吐的关键。
    • Offset 有效性检查防止读取过期或不存在的数据。
  1. Broker 角色
    • 同时承担 Leader 和 Follower 副本的读写协调。
http://www.lryc.cn/news/537718.html

相关文章:

  • 用大模型学大模型05-线性回归
  • Python实现AWS Fargate自动化部署系统
  • 国产编辑器EverEdit - 上下翻滚不迷路(历史编辑位置、历史光标位置回溯功能)
  • 今日写题work05
  • [C++语法基础与基本概念] std::function与可调用对象
  • 两个实用且热门的 Python 爬虫案例,结合动态/静态网页抓取和反爬策略,附带详细代码和实现说明
  • 华象新闻 | 2月20日前谨慎升级 PostgreSQL 版本
  • 跳跃游戏 II - 贪心算法解法
  • 图像质量评价指标-UCIQE-UIQM
  • CentOS上安装WordPress
  • Spring Boot 原理分析
  • Git 本地项目上传 GitHub 全指南(SSH Token 两种上传方式详细讲解)
  • jenkins服务启动-排错
  • CF 144A.Arrival of the General(Java实现)
  • SAP-ABAP:SAP中REPORT程序和online程序的区别对比
  • Java发展史
  • vue3--SVG图标的封装与使用
  • Datawhale Ollama教程笔记3
  • 学习数据结构(10)栈和队列下+二叉树(堆)上
  • 洛谷 P3660 USACO17FEB Why Did the Cow Cross the Road III 题解
  • 【数据结构】(9) 优先级队列(堆)
  • 如何提升爬虫获取数据的准确性?
  • Obsidian及Zotero常用的插件
  • 闲鱼IP属地是通过电话号码吗?
  • C#多线程异步连接MySQL与SQLserver数据库
  • 51单片机-数码管
  • C#学习之S参数读取(s2p文件)
  • Spring Boot “约定大于配置”
  • 传输层协议TCP ( 下 )
  • NLP 八股 DAY1:BERT