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

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

一 常用解决方案

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

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下安装和使用Dokuwiki

    Dokuwiki作为一个wiki引擎,软件主体十分小巧但功能非常强大而又灵活。它语法简单,为易写性、易读性提供保障。它提供权限管理和安全策略,能够保证信息库的安全性。 需求 Dok…

    Linux系统 2025年6月8日
  • 详解cron与anacron

    cron 是 linux 中运行例行性工作的一个服务,守护进程是crond,是一个用于运行计划任务如系统备份、更新等的守护进程。它适合在那些 7×24 小时不间断运行的机器如服务器…

    Linux系统 2025年6月27日
  • Linux中nmcli命令使用方法

    nmcli命令是redhat7或者centos7之后的命令,该命令可以完成网卡上所有的配置工作,并且可以写入配置文件,永久生效,下面为大家讲解一下nmcli命令使用方法。 基本用法…

    Linux系统 2025年6月8日
  • CentOS 8上安装GCC具体方法

    Linux系统下的gcc(GUN C Complier)是GUN的缩写。 在Linux和Unix下,一般我们使用gcc进行编译 c和c++代码,本篇文章重点为大家讲解一下CentO…

    Linux系统 2025年6月4日
  • 详解Linux Base64

    Base64编码在电子邮件中很常见,Foxmail、Outlook等邮件用户代理发邮件时进行SMTP验证,就是输入base64编码格式的用户名和密码进行验证的,而邮件的主体内容和附…

    Linux系统 2025年9月21日
  • APFS为何如此之强

    Apple 文件系统 (APFS) 是 Mac 电脑的默认文件系统格式,具有强加密、空间共享、磁盘快照、快速目录大小统计等特性,以及改进的文件系统基础。虽然 APFS 最适合于新款…

    Linux系统 2025年10月10日
  • SELinux策略规则查看方法(seinfo和sesearch)详解

    我们知道,当前 SELinux 的默认策略是 targeted,那么这个策略中到底包含有多少个规则呢?使用 seinfo 命令即可查询。命令如下: [root@localhost …

    Linux系统 2025年6月8日
  • 如何实用tar命令备份还原Linux系统

    Linux tar(英文全拼:tape archive )命令用于备份文件。tar 是用来建立,还原备份文件的工具程序,它可以加入,解开备份文件内的文件。 备份 打开终端,切换到r…

    Linux系统 2025年10月25日
  • Linux中历史命令的具体使用方法

    Linux系统当你在shell(控制台)中输入并执行命令时,shell会自动把你的命令记录到历史列表中,一般保存在用户目录下的.bash_history文件中。默认保存1000条,…

    Linux系统 2025年7月6日
  • Linux下安装和使用ClamAV具体方法

    ClamAV是Linux平台上领先的开源病毒扫描程序,如果你要为Linux桌面或服务器找到一个好的病毒扫描程序,这个应用程序应该是你的首选,下面为大家分享一下Linux下安装和使用…

    Linux系统 2025年9月23日

发表回复

登录后才能评论