可靠消息服务实现具体方案

分布式事务往往是服务化的痛点,很多场景通过业务避免了分布式事务,但是还是存在一些场景必须依赖分布式事务,下面来讲讲如何处理分布式事务

一 常用解决方案

分布式事物解决方式有很多,网上博客也有一大堆 总结一般有如下两种

1 刚性分布式事务,两阶段提交 强一致性

2 柔性分布式事务 最大努力提交 ,tcc,可靠消息服务

首先解决分布式事务前提保障:接口必须幂等性,防止消息重复发送对业务影响

二 可靠消息系统设计(这个感觉不错比较简单,就拿来分享下)

如上图

开始执行 比如:try{if(prepare()) { //预发送阶段doService(); //执行业务逻辑updateMsgStatus();//更新消息为确认状态}}

1 预发送消息,try阶段,如果预发送消息失败了,业务还未执行,所以 系统A,B还是一致性的 不需要处理

这一点容易理解

2 预发送消息成功了,开始执行业务逻辑。执行成功 更新预发送消息转态为确认发送。如果 此时 业务逻辑执行失败了,那预发送消息就不会跟新状态,此时消息确认系统就开启工作,到业务系统1上回查此消息状态,此时发现业务执行失败了,就更新预发送状态至失败状态。

3 如果此时 业务执行成功了消息也被更新成确认发送了 那就ok 完美。如果消息更新失败,还是由消息确认系统回查转态 更新此消息被删除状态还是确认发送状态。

4 消息者开始消费

1> 比如消费失败了,此时产生不一致, 消息恢复系统检测消息状态,重新发送消息

2>如果执行业务失败了,此消息也就不会被确认了,还是由消息恢复系统检测消息状态,重新发送消息

3>如果ask失败了,还是以上逻辑重新发送上诉重新发送当然有次数限制,不能一直发送,超过最大次数就要进入死信队列,等待人工干预了

4> ask成功,消息也就成功消费了,完美,解决了消息可靠服务

三 努力提交

这个比较简单 ,将失败的消息重复提交,实时性比较弱的一些场景,确保消息推送成功。

比如交易完成推送第三方消息。 此时可以使用努力提交

原创文章,作者:晴川运维,如若转载,请注明出处:https://baike.qcidc.com/11931.html

(0)
晴川运维晴川运维
上一篇 2025年7月8日
下一篇 2025年7月8日

相关推荐

  • Linux下查看GPU信息命令

    现在不管是分布式还是其他服务器还是深度学习训练模型等,都离不开GPU,因此了解一下GPU常见的参数命令以及性能指标是十分重要的,本篇文章重点为大家讲解一下Linux下查看GPU信息…

    Linux系统 2025年7月1日
  • 如何使用 Linux anacron 命令

    与其手动执行重复性的任务,不如让 linux 为你做。 在 2021 年,人们有更多的理由喜欢 Linux。在这个系列中,我将分享使用 Linux 的 21 个不同理由。自动化是使…

    Linux系统 2025年6月8日
  • 最受欢迎的10款Python开源框架总结

    本篇文章为大家讲解一下10个在GitHub等开源网站中最欢迎的Python开源框架,为大家做详细介绍和优劣势总结。这些框架包括Web开发,高性能网络通信,测试,爬虫等。 1.Dja…

    Linux系统 2025年6月29日
  • Dockerfile中COPY 和 ADD命令

    Dockerfile 中提供了两个非常相似的命令 COPY 和 ADD,本篇文章为大家讲解两个命令的基本功能,以及其异同点,然后总结其各自适合的应用场景。 Build 上下文的概念…

    Linux系统 2025年7月2日
  • 详解Mariadb聚合函数及分组查询

    MariaDB Server 是最流行的开源关系型数据库之一。它由 MySQL 的原始开发者制作,并保证保持开源。它是大多数云产品的一部分,也是大多数Linux发行版的默认配置。M…

    Linux系统 2025年6月8日
  • HTML 元素使用实例

    HTML 文档是由 HTML 元素定义的。HTML 元素指的是从开始标签(start tag)到结束标签(end tag)的所有代码,下面为大家详细讲解一下HTML 元素 HTML…

    Linux系统 2025年6月8日
  • 非常实用的Vim插件

    工欲善其事必先利其器,windows 环境下有诸多好用的 IDE,但在 linux 环境下,可供选择的工具并不多,但是 VIM 作为一款可扩展文本编辑工具,配合丰富的功能插件,同样…

    Linux系统 2025年9月21日
  • AWK读取标准输入具体方法

    在 awk 系列中,我们将会看到几个例子,你可以筛选其他命令的输出代替从一个文件读取输入作为 awk 的输入。我们首先从使用 dir 命令开始,它类似于 ls 命令。 在第一个例子…

    Linux系统 2025年6月4日
  • 详解Shell 软件—Zsh

    Zsh 是一款功能强大的 Shell 软件,既可以作为交互式终端来使用,也可以作为脚本语言解释器来使用。它在兼容 POSIX 的 sh 的同时(默认不兼容,仅在使用 emulate…

    Linux系统 2025年7月5日
  • 使用unzip命令解压缩文件

    unzip解压命令的使用方法:【unzip test.zip】,表示将压缩文件test.zip解压到当前目录下。unzip命令用于解压缩由zip命令压缩的【.zip】压缩包。 安装…

    Linux系统 2025年10月27日

发表回复

登录后才能评论