当前位置:网站首页>使用RabbitMQ实现分布式事务
使用RabbitMQ实现分布式事务
2020-11-07 16:49:00 【php开源社区】
RabbitMQ解决分布式事务思路:
案例:经典案例,以目前流行点外卖的案例,用户下单后,调用订单服务,让后订单服务调用派单系统通知送外卖人员送单,这时候订单系统与派单系统采用MQ异步通讯。
RabbitMQ解决分布式事务原理:采用最终一致性原理。
需要保证以下三要素
1、确认生产者一定要将数据投递到MQ服务器中(采用MQ消息确认机制)
2、MQ消费者消息能够正确消费消息,采用手动ACK模式(注意重试幂等性问题)
3、如何保证第一个事务先执行,采用补偿机制,在创建一个补单消费者进行监听,如果订单没有创建成功,进行补单。
如果生产者投递消息到MQ服务器成功
场景1:如果消费者消费消息失败了,生产者是不需要回滚事务的。
解决方案:消费者采用手动ack应答模式,采用MQ进行补偿重试机制,注意MQ补偿幂等性问题。
问题:如何确保生产者投递消息到MQ服务器一定能成功?
解决方案:confirm机制(确认应答机制)。
场景2 如果生产者投递消息到MQ服务器失败,如何解决?
解决方案:使用生产者重试机制进行发消息,注意幂等性问题。
场景3 如何保证一个事务先执行,生产者投递消息到MQ服务器成功,消费者消费成功了,但是订单却回滚了。
解决方案:补单机制。
传统解决方式:
RabbitMq解决方案:
版权声明
本文为[php开源社区]所创,转载请带上原文链接,感谢
https://my.oschina.net/u/4479011/blog/4707610
边栏推荐
- August 14, 2020: what are the execution engines for data tasks?
- Win7 how to quickly type CMD and get to the required directory
- September 9, 2020: naked writing algorithm: two threads print numbers 1-100 in turn.
- How to optimize the decoding performance of dynamsoft barcode reader
- yum [Errno 256] No more mirrors to try 解决方法
- Empty test suite appears in JUnit test
- Ora-02292: complete constraint violation (midbjdev2.sys_ C0020757) - subrecord found
- Google browser realizes video playback acceleration function
- The memorandum model of behavior model
- Count the number of project code lines
猜你喜欢
Python3 operating gitlab
大佬们如何在nginx镜像里面增加模块?
REM: the solution of PC and mobile
August 18, 2020: introduce Mr process?
idea 激活到 2089 失效
JS string - string string object method
How to solve the problem of blank page in Google Chrome browser
How to optimize the decoding performance of dynamsoft barcode reader
How to add modules to nginx image?
测试攻城狮必备技能点!一文带你解读DevOps下的测试技术
随机推荐
小程序商城系统插件代码该如何写?怎么用代码检查添加插件是否成功?
Epu360: all the H5 templates you want are here, e-book, big turntable, red envelope rain, questionnaire survey
ado.net and asp.net The relationship between
Detailed software engineering -- the necessary graphs in each stage
How to add modules to nginx image?
Jenkins pipline stage setting timeout
Top 5 Chinese cloud manufacturers in 2018: Alibaba cloud, Tencent cloud, AWS, telecom, Unicom
插件Bilibili新版0.5.5
轻量型 GPU 应用首选 京东智联云推出 NVIDIA vGPU 实例
win7如何快速打cmd并到达所要的目录
The method of local search port number occupation in Windows system
如何使用甘特图图层和筛选器
Do you really know how to use search engines?
August 14, 2020: what are the execution engines for data tasks?
Design of NAND flash interface control
谈了多年的数字化转型,为什么还有很多企业依然“口头管理”
2018中国云厂商TOP5:阿里云、腾讯云、AWS、电信、联通 ...
7. Swarm builds clusters
关于DevOps的七大误解,99%的人都曾中过招!
Composition of MRAM cache