
阿里云国际站经销商,主营阿里云,腾讯云,华为云,亚马逊aws,谷歌云gcp,微软云az,免费开户,代充值优惠大,联系客服飞机@jkkddd
前提条件
您已创建以下队列,具体操作,请参见创建队列。
事务消息队列
消息存活时间小于消息延时时间。
当消息发送成功、事务操作成功时,生产者修改消息延迟时间,消息对消费者可见。
当消息发送成功、事务操作失败时,生产者不修改消息延迟时间,消息对消费者不可见。
操作日志队列
记录事务消息的操作记录信息。消息延时时间为事务消息操作超时时间。日志队列中的消息确认后将对消费者不可见。
原理介绍
一些业务场景需要保证本地操作和消息发送的事务一致性,即消息发送成功,本地操作成功。如果消息发送成功,本地操作失败,那么发送成功的消息需要回滚。
消息发送成功,事务操作成功时操作步骤如下所示:
生产者发送一条事务准备消息到事务消息队列。
生产者发送操作日志消息到操作日志队列,日志中包含步骤1消息的消息句柄。
生产者执行本地事务操作成功。
生产者请求修改消息延迟时间,使消息对消费者可见。
生产者向操作日志队列确认操作日志,删除日志消息。
消费者从事务消息队列中接收事务消息。
消费者处理事务消息。
消费者请求删除事务消息。
消息发送成功,事务操作失败时操作步骤如下所示:
生产者发送一条事务准备消息到事务消息队列。
生产者发送操作日志信息到操作日志队列,日志中包含步骤1消息的消息句柄。
生产者执行本地事务操作失败。
操作日志队列向生产者发送消息,请求读取超时未确认操作日志。
生产者检查事务结果,发现操作失败。
生产者提交回滚消息请求,不修改消息延迟时间,消息对消费者不可见。
生产者向操作日志队列确认操作日志,删除日志消息。
示例代码
消息服务MNS最新的Java SDK(1.1.8)中的TransactionQueue支持上述事务消息方案。在TransactionOperations和TransactionChecker两个接口添加业务操作和检查逻辑,您就可以方便地实现事务消息
异常分析
生产者异常(例如进程重启)
读取操作日志队列中超时未确认日志。
检查事务结果。
如果检查到事务执行成功,则提交消息。
确认操作日志。
消费者异常(例如进程重启)
消息服务MNS提供至少保证消费一次的特性,如果当前消费者没有成功消费并删除消息,消息在不可见时间后将继续可见,被当前消费者或者其他消费者处理。
消息服务MNS服务不可达(例如断网)
消息发送和接收处理状态及操作日志都在消息服务MNS服务端,消息服务MNS本身具备高可靠和高可用的特点,所以只要网络恢复正常,事务就可以继续进行。只要生产者操作成功,消费者就能收到消息并成功处理;如果生产者操作失败,则消费者无法收到消息。

温馨提示:尊敬的[]站点管理员,将本页链接加入您的网站友情链接,下次可以快速来到这里更新您的站点信息哦!每天更新您的[阿里云国际代理商,阿里云账号24h自助充值]站点信息,可以排到首页最前端的位置,让更多人看到您站点的信息哦。
将下面的代码插入您网页中,让网友帮您更新网站每日SEO综合情况
-
传奇游戏将在多个平台发布数字藏品 -
互联网开展至今,出现过良多着名的网游产品,玩家通过参取游戏从而获得利润的游戏模式已渐渐成生,但因为种种不行控身分,导致游戏内部经济模型渐渐衰败,从而使一款优质的游
-
投资人加盟儿童美术教育的关键因素解析 -
在当今教育市场中,儿童美术教育正变得越来越受欢迎,更多的投资人开始考虑加盟这个行业。然而,作为一个投资人,在 加盟儿童美术教育 之前你需要考虑哪些因素呢? 第一,你应
-
深圳车辆抵押贷款银行-深圳抵押朋友车 -
深圳车辆抵押贷款银行,深圳抵押朋友车联系:13530875815,深圳汽车抵押贷款恒鸿,深圳押车贷款雷经理,深圳按揭车贷款先息后本贷款,短期借款,技术专业申请办理深圳压证不押车贷
-
如何延长煤厂洗车设备的使用寿命 -
在一些特殊的场地使用,如煤矿、垃圾处理厂、混凝土搅拌站、大的养殖场等污染比较严重的地方,这些场所更容易造成喷孔和水泵堵塞,损坏水泵和设备。所以在使用 煤厂洗车设备
-
二次结构泵-10米轻便浇柱,室内轻松施工省时又省力 -
在建筑施工中,二次结构泵可谓是不可或缺的好帮手 , 这款设备特别适用于 10米轻便浇柱,让室内施工变得轻松省力,既省时又省力。 二次结构泵 就像一位默默付出的辛勤工作者,让
-
实时监控,灵活适应——SMT智能料架的出色表现_佰斯特POUSTO -
SMT智能料架 搬运系统(SmartMaterialHandlingSystem,简称SMT)是一种应用于物流和仓储领域的智能技术。 通过自动化和智能化的方式,提高了物料搬运和储存的效率,SMT智能料架的优点有很