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

kafka消息的顺序性如何保持一致的

目录

背景:

原理:

情况一:如果只有一个分区

情况二:如果有多个分区

总结


背景

最近面试总是被问这个问题,然后总感觉答得不好就写博客总结一下,可以先看总结

原理:

Kafka 中,同一个分区内的消息是按照写入顺序依次存储的,并且每条消息都有一个递增的 offset。因此:
  • 只要生产者按顺序发送
  • 消费者按顺序读取
就可以保证这个分区里的消息是有序的
情况一:如果只有一个分区
如果 Topic 只有一个分区,那么我们只需要配置一个消费者去顺序地消费这个分区,就可以天然保证消息顺序性。 这是最简单、最直接的顺序消费方式
情况二:如果有多个分区
多个分区的情况下,我们通常需要做两件事:
1. 使用 Key + 分区策略,让“同一类消息”发送到同一个分区
  • 所谓“同一类消息”,指的是那些你希望它们保持顺序的一组消息。
  • 比如说:我们只要求“同一个用户”的消息是有序的,而不同用户之间没关系。
  • 那么可以通过用户 ID 做 Hash 或取余,将相同用户的消息分配到同一个分区中。
这样就保证了“同一用户的消息”都落在同一个 Partition 上,具备了 顺序性保障的基础条件
2. 保证同一分区的消息是串行写入 + 串行消费
  • 发送端
要确保写入同一分区的消息是按顺序串行发出的,不能并发打乱顺序。
  • 消费端
则要保证每个分区只由一个线程、协程或消费者去消费,这样消费逻辑才是串行的。

总结

Kafka 只保证“ 每个分区内”消息的顺序性。如果你想让某类消息保持顺序,就必须做到:
✅ 把这些消息发到同一个分区(通过 Key 控制)
✅ 串行写入这些消息
✅ 串行消费这个分区
http://www.dtcms.com/a/163762.html

相关文章:

  • Windows 10系统中找回MySQL 8的root密码
  • 智能电子白板的设计与实现:从硬件选型到软件编程
  • python初学
  • 基于Spring Boot 电商书城平台系统设计与实现(源码+文档+部署讲解)
  • python celery框架结合django的使用
  • 深度剖析 RocketMQ 5.0 之架构解析:云原生架构如何支撑多元化场景?
  • 浅析通用文字识别技术在档案管理中的未来发展趋势
  • MySQL学习总结
  • 【2024-NIPS-版权】Evaluating Copyright Takedown Methods for Language Models
  • 使用Qt QAxObject解决Visual Fox Pro数据库乱码问题
  • 马井堂-区块链技术:架构创新、产业变革与治理挑战(马井堂)
  • 代码随想录第39天|leetcode198.打家劫舍、leetcode213.打家劫舍II 、leetcode337.打家劫舍III
  • JVM GC垃圾回收算法
  • 基于Vue3和OpenLayers的WebGIS示例程序
  • 0429/AIGC model mark Blog
  • 【Linux系统篇】:线程的本质---重新定义并发执行单元
  • 借助Spring AI实现智能体代理模式:从理论到实践
  • 系统思考培训助力总经理
  • 音视频之H.265/HEVC网络适配层
  • C++学习之shell高级和正则表达式
  • 3D可视化编辑器模版
  • flask中的Response 如何使用?
  • Android ndk 编译opencv后部分接口std::__ndk1与项目std::__1不匹配
  • 4.27搭建用户界面
  • 前端vue2修改echarts字体为思源黑体-避免侵权-可以更换为任意字体统一管理
  • 天能资管(SkyAi):全球布局,领航资管新纪元
  • 线程数据同步的三种方式
  • Ansible 守护 Windows 安全(Ansible Safeguards Windows Security)
  • 大数据测试集群环境部署
  • Java实现使用EasyExcel按模板导出文件