当前位置:首页 > 科技  > 软件

三分钟白话RocketMQ系列—— 如何保证消息顺序性

来源: 责编: 时间:2023-09-21 20:48:20 362观看
导读关键字摘要全局有序局部有序局部有序能一直有序吗顺序消息的限制Q1:什么是全局有序?如何实现全局有序?适用于性能要求不高,所有的消息严格按照先进先出(FIFO)的原则来发布和消费的场景。例如,在证券处理中,以人民币兑换美元为

QmY28资讯网——每日最新资讯28at.com

关键字摘要

  • 全局有序
  • 局部有序
  • 局部有序能一直有序吗
  • 顺序消息的限制

Q1:什么是全局有序?如何实现全局有序?

适用于性能要求不高,所有的消息严格按照先进先出(FIFO)的原则来发布和消费的场景。QmY28资讯网——每日最新资讯28at.com

例如,在证券处理中,以人民币兑换美元为Topic,在价格相同的情况下,先出价者优先处理,则可以按照FIFO的方式发布和消费全局顺序消息。QmY28资讯网——每日最新资讯28at.com

要实现全局有序,必须控制Topic只有一个队列queue,才能实现全局有序。QmY28资讯网——每日最新资讯28at.com

由于只有一个队列存在,这种方式虽然保证了全局有序,但是性能不高,无法扩展。QmY28资讯网——每日最新资讯28at.com

Q2:什么是局部有序?如何实现局部有序?

适用于性能要求高,以Sharding Key作为分区字段,在同一个队列queue中严格地按照FIFO原则进行消息发布和消费的场景。QmY28资讯网——每日最新资讯28at.com

例如,用户注册需要发送发验证码,以用户ID作为Sharding Key,那么同一个用户发送的消息都会按照发布的先后顺序来消费。QmY28资讯网——每日最新资讯28at.com

保证「消息生产」的顺序性,则必须满足以下条件:QmY28资讯网——每日最新资讯28at.com

  • 单一生产者:消息生产的顺序性仅支持单一生产者,不同生产者分布在不同的系统,即使设置相同的分区键,不同生产者之间产生的消息也无法判定其先后顺序。
  • 串行发送:生产者客户端支持多线程安全访问,但如果生产者使用多线程并行发送,则不同线程间产生的消息将无法判定其先后顺序。

满足以上条件的生产者,将 「顺序消息」 发送至服务端后,会保证设置了同一分区键的消息,按照发送顺序存储在同一队列中。QmY28资讯网——每日最新资讯28at.com

局部有序(分区有序)QmY28资讯网——每日最新资讯28at.com

注意,在RocketMQ 5.x版本中,新增了「消息组」概念,顺序消息发送必须要设置消息组。QmY28资讯网——每日最新资讯28at.com

保证「消息消费」的顺序性,则必须满足以下条件:QmY28资讯网——每日最新资讯28at.com

  • 语义正确。业务方消费消息时需要严格按照 接收---处理---应答 的语义处理消息,避免因异步处理导致消息乱序。
  • 有限重试。顺序消息消费投递次数限定有限范围内,即一条消息如果超过最大重试次数后,将跳过这条消息消费,不会一直阻塞后续消息处理。

对于需要严格保证消费顺序的场景,请务必设置合理的重试次数,避免参数不合理导致消息乱序。QmY28资讯网——每日最新资讯28at.com

Q3:如果Broker掉线,局部有序还能保持有序吗?

如果一个Broker掉线,那么此时队列总数是否会发化?QmY28资讯网——每日最新资讯28at.com

如果发生变化,那么同一个 ShardingKey 的消息就会发送到不同的队列上,造成乱序。QmY28资讯网——每日最新资讯28at.com

如果不发生变化,那消息将会发送到掉线Broker的队列上,必然是失败的。QmY28资讯网——每日最新资讯28at.com

因此 Apache RocketMQ 提供了两种模式,如果要保证严格顺序而不是可用性,创建 Topic 是要指定 -o 参数(--order)为true,表示顺序消息:QmY28资讯网——每日最新资讯28at.com

$ sh bin/mqadmin updateTopic -c DefaultCluster -t TopicTest -o true -n 127.0.0.1:9876create topic to 127.0.0.1:10911 success.TopicConfig [topicName=TopicTest, readQueueNums=8, writeQueueNums=8, perm=RW-, topicFilterType=SINGLE_TAG, topicSysFlag=0, order=true, attributes=null]

其次,要保证NameServer中的配置 orderMessageEnable 和 returnOrderTopicConfigToBroker 必须是 true。QmY28资讯网——每日最新资讯28at.com

如果上述任意一个条件不满足,则是保证可用性而不是严格顺序。QmY28资讯网——每日最新资讯28at.com

Q4: 顺序消息有哪些限制?

同一条消息是否可以既是顺序消息,又是定时消息和事务消息?QmY28资讯网——每日最新资讯28at.com

不可以。顺序消息、定时消息、事务消息是不同的消息类型,三者是互斥关系,不能叠加在一起使用。QmY28资讯网——每日最新资讯28at.com

为什么全局顺序消息性能一般?QmY28资讯网——每日最新资讯28at.com

全局顺序消息是严格按照FIFO的消息阻塞原则,即上一条消息没有被成功消费,那么下一条消息会一直被存储到Topic队列中。QmY28资讯网——每日最新资讯28at.com

关键字总结

  • 全局有序:必须控制Topic只有一个队列queue,才能实现全局有序,性能一般。
  • 局部有序:性能较好,需要确保「生产有序」和「消费有序」,同时注意Broker掉线时的 可用性 与 有序性 权衡。

本文链接:http://www.28at.com/showinfo-26-10904-0.html三分钟白话RocketMQ系列—— 如何保证消息顺序性

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 实用!Python数据去重与唯一值提取:高效整理数据

下一篇: 什么是 Merge Queue,为什么要使用它?

标签:
  • 热门焦点
  • 影音体验是真的强 简单聊聊iQOO Pad

    大公司的好处就是产品线丰富,非常细分化的东西也能给你做出来,例如早先我们看到了新的vivo Pad2,之后我们又在iQOO Neo8 Pro的发布会上看到了iQOO的首款平板产品iQOO Pad。虽
  • 印度登月最关键一步!月船三号今晚进入环月轨道

    8月5日消息,据印度官方消息,月船三号将于北京时间今晚21时30分左右开始近月制动进入环月轨道。这是该探测器能够成功的最关键步骤之一,如果成功将开始围
  • Rust中的高吞吐量流处理

    作者 | Noz编译 | 王瑞平本篇文章主要介绍了Rust中流处理的概念、方法和优化。作者不仅介绍了流处理的基本概念以及Rust中常用的流处理库,还使用这些库实现了一个流处理程序
  • 从 Pulsar Client 的原理到它的监控面板

    背景前段时间业务团队偶尔会碰到一些 Pulsar 使用的问题,比如消息阻塞不消费了、生产者消息发送缓慢等各种问题。虽然我们有个监控页面可以根据 topic 维度查看他的发送状态,
  • 拼多多APP上线本地生活入口,群雄逐鹿万亿市场

    Tech星球(微信ID:tech618)文 | 陈桥辉 Tech星球独家获悉,拼多多在其APP内上线了“本地生活”入口,位置较深,位于首页的“充值中心”内,目前主要售卖美食相关的
  • 猿辅导与新东方的两种“归途”

    作者|卓心月 出品|零态LT(ID:LingTai_LT)如何成为一家伟大企业?答案一定是对“势”的把握,这其中最关键的当属对企业战略的制定,且能够站在未来看现在,即使这其中的
  • 冯提莫签约抖音公会 前“斗鱼一姐”消失在直播间

    来源:直播观察提起“冯提莫”这个名字,很多网友或许听过,但应该不记得她是哪位主播了。其实,作为曾经的“斗鱼一姐”,冯提莫在游戏直播的年代影响力不输于现
  • 荣耀Magicbook V 14 2021曙光蓝版本正式开售,拥有触摸屏

    荣耀 Magicbook V 14 2021 曙光蓝版本正式开售,搭载 i7-11390H 处理器与 MX450 显卡,配备 16GB 内存与 512GB SSD,重 1.48kg,厚 14.5mm,具有 1.5mm 键盘键程、
  • 与兆芯合作 联想推出全新旗舰版笔记本电脑开天N7系列

    联想与兆芯合作推出全新联想旗舰版笔记本电脑开天 N7系列。这个系列采用兆芯KX-6640MA处理器平台,KX-6640MA 处理器是采用了陆家嘴架构,16nm 工艺,4 核 4 线
Top