Seata-DTX|分布式事务金融场景案例介绍

news2024/11/15 2:09:10

c5a6cc25e3000d783cafc2ec62d9b924.gif

文|魏陈豪(花名:无陈 Sam)

蚂蚁集团 SOFAStack 产品专家

3c3640ddc48f44dc7868a394f53578b0.png

本文 2966 字 阅读 8 分钟

序言

今天给大家带来一篇 Seata-DTX[1] 商业版分布式事务在金融行业如何保证事务一致性的实践介绍。从一个全局视角出发看看一致性的保证、分别有哪些节点,事务组件在其中处在一个什么位置、担任什么工作。

分布式系统下的事务问题阐述

云原生应用以分布式系统为主,应用会被切分到多个分布式的微服务系统下。拆分一般分为水平拆分和垂直拆分,这并不仅仅单指对数据库或者缓存的拆分,主要是表达一种分而治之的思想和逻辑。

分布式系统的底层无法逃离“CAP 的不可能三角”(C: Consistency,一致性;A: Availability,可用性;P: Partition Tolerance,分区容忍性)。CAP 原理证明,任何分布式系统只可同时满足以上两点,无法三者兼顾。而分布式的服务化系统都需要满足分区容忍性,那么必须在一致性和可用性之间进行权衡。

如果网络发生异常情况,导致分布式系统中部分节点之间的网络延迟不断增大,可能会导致分布式系统出现网络分区。复制操作可能会被延后,如果这时我们的使用方等待复制完成再返回,则可能导致在有限时间内无法返回,就失去了可用性;如果使用方不等待复制完成,而在主分片写完后直接返回,则具有了可用性,但是失去了一致性。

f4c2a91f00931f896b3312561a679aee.png

图 1 CAP 理论

图片出处:https://lushunjian.github.io/blog/2018/06/20/CAP%E7%90%86%E8%AE%BA/

金融机构对一致性的诉求

对金融机构而言,架构层面的高可用和业务层面的强一致性,几乎同样重要。这就需要金融级云原生能够很好地平衡“CAP 的不可能三角”,需要尽可能兼顾业务强一致与系统高可用。

但是“一致性挑战”在分布式系统中绝不仅仅是一个数据库问题,而是一个大的话题。其涵盖分布式系统的各个层面:事务一致性、节点一致性、系统间业务一致性、消息幂等一致性、缓存一致性、跨 IDC 一致性等等。所以也需要云原生架构有一系列技术能够应对金融级对一致性的严苛挑战。

一致性控制的几个重要维度

这里挑选几个常见的金融场景下需要解决的一致性维度进行阐述。

事务级事务级别的一致性控制需要根据不同的金融场景选择合适的分布式事务模式。在我们针对 Seata-DTX 的客户进行调研后,发现大多数客户在平衡成本和性能后,基于 SAGA 和 TCC 是目前金融机构比较常用的两种分布式事务模式。SAGA 模式对应用实现侵入性更小,但基于补偿事务来保障一致性的设计、前后步骤执行过程中不保证事务隔离性;而 TCC 模式能做到比较好的事务隔离性,但需要应用层感知更多的复杂度。

对于事务流程中部分不需要同步返回结果的节点,为提高执行效率可采用异步消息队列实现,对于一些事务流程较长的场景可明显降低事务实现复杂度、削峰填谷。典型场景如客户购买理财场景简化分为存款账户扣款和理财账户入账两个步骤,若选用 SAGA 模式,存款账户成功扣款后、理财账户入账失败,客户会看到“钱已付、货没到”的中间异常状态,需要系统进行冲正存款账户扣款来保障事务一致性。如选用 TCC 模式,先后完成存款账户扣款、理财账户入账的逻辑处理,各自需要存款系统和理财系统记录逻辑处理的状态,二者均成功后再发起统一提交。

数据库级:接下来是数据库层面,金融场景下对于数据不丢有着极致的要求:一方面需要在同城、异地多个机房保存多个副本,另一方面需要在多个副本之间实现数据同步,Seata-DTX 的高可用也是依赖数据库之间的数据同步进行保障的。整体作用是以防一个 Seata-DTX 事务集群宕机后,切换到另外一套 Seata-DTX 事务集群后,可以恢复到正在进行中的事务记录,保障同城分布式事务的 RPO 为零、异地 RPO 接近零。数据库同步中,如果使用的是分布式事务库,分布式数据库一般通过对 Paxos 的支持来实现跨多服务器,甚至跨多中心的数据一致性保证。

机房级:跨机房的路由能力、异常事务的跨机房恢复能力。发生机房故障时,数据库需要能够切到同城/异地的副本、并保障 RPO 为零,配合应用层的交易路由切换,完成机房级容灾切换、恢复业务。期间因机房故障导致的部分交易事务流程中断,分布式事务组件需要具备自动恢复能力,重新启动中断的事务流程按事先设定的业务规则向前完成或向后冲正。

真实金融客户案例

以某资产规模超过 2 万亿元的省级农信为例,来看一下在核心整体下移的过程中,如何使用事务、配合数据库,机房容灾进行一致性控制。

首先介绍一下整体的业务架构,在新核心平台中,大致可以分为产品服务层、交易中心层、交易中台层,如图 1 所示。交易中心收口所有的交易流程,对产品服务提供交易能力。最下面是交易原子能力层,主要包含 8 个中台,中台不直接对上提供服务,由交易中心统一处理。整个交易中心的能力,都基于服务编排构建,在编排流程中使用 SAGA 事务进行流程一致性控制。

9b57b8ee56fad8b6b47ae57f4e83ced6.png

图 2 分布式新核心下移平台分层架构

以贷款产品为例:整体的贷款支取、还款等长流程在信贷产品系统中,由 SAGA 事务进行串联,核心的资金交换部分由 TCC 事务把控一致性,做到对整体长流程里多个应用实现较小的侵入性。但基于补偿事务来保障一致性的设计、前后步骤执行过程中不保证事务隔离性,因此用 TCC 模式来处理对隔离性有较强诉求的核心资金交换服务,如图 3 所示。

a59eecdba221a5bbbc6c7c8941b6faac.png

图 3 核心下移智能贷款系统流程

如下图 4 是上述图 3 信贷产品中的还贷流程 TCC 流程示例。启动 TCC 事务后,使用 try 先尝试锁定客户账户余额,锁定成功后,等待二阶段提交。尝试 try 换贷款利息,锁定成功。整体提交事务,进行二阶段的扣账 confirm,以及还利息 confirm。

1fde271d763a5bf201af3346606c9f5b.png

图 4 核心下移智能贷款 TCC 流程

事务层面的一致性进行了保证后,针对客户的 2 地机房进行事务的高可用部署,如图 5 所示。

9b90c739ba88d7c360bc51128cb0d765.png

图 5 金融级云原生分布式事务部署架构

Console 是分布式事务的配置控制台,用户访问时通过 VIP 路由到不同机房的 console,数据写入到主 DB,主备 DB 数据实时同步。

Seata-DTX Server 为分布式事务异库模式下的事务控制器和事务恢复器。其主要是记录事务日志,发起二阶段调用以及异常事务的恢复任务。

业务应用用过 VIP 获取 Seata-DTX Server 对应的 IP。事务发起方发起事务时,事务日志都写入到主 DB 中,数据同步到备 DB。

当福州 IDC 宕机或者断电时,流量会全部路由到上海 IDC。备数据库中因为有主 DB 的所有事务记录,当控制台查看事务数据和发起恢复事务任务时,仍然能正常执行。(当然可能会有人问这个情况下会不会频繁出现跨机房的分布式事务影响性能,此处负载均衡会基于入口流量的单元信息,自动调拨流量到对应的机房。此处不过多进行阐述。)

综上可以看出,当前 Seata-DTX 的架构设计中,不单单是在事务层面去控制一致性。当有多个地域,多个副本时,可能需要结合数据库保证事务数据的一致。在多机房的情况下,需要依赖容灾能力,保证交易事务的流程可恢复。

[1]Seata-DTX:

https://help.aliyun.com/document_detail/132903.html?spm=a2c4g.132901.0.0.4bcb3c9b6bg9ik

Seata Star 一下

https://github.com/seata/seata

  本周推荐阅读  

862a57495ab93649d5a876acfdedb2cf.png

Seata Saga 模式快速入门和最佳实践

d031353d582b6cb04d8ef55de0c0bb17.png

生产环境可用的 Seata-go 1.2.0 来啦!!!

c6748dd0c23a8b8459b89d04e95355cc.jpeg

Seata-go 1.1.0 发布,补齐 AT 模式支持

163e2a4c2a6a414c1b898e86701b8c7f.png

Seata AT 模式代码级详解

b93740afb852f7a0d915dec44c3e592f.jpeg

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/697828.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

全志科技T3国产工业评估板规格书(四核ARM Cortex-A7,主频1.2GHz)

1 评估板简介 创龙科技TLT3-EVM是一款基于全志科技T3处理器设计的4核ARM Cortex-A7高性能低功耗国产评估板,每核主频高达1.2GHz,由核心板和评估底板组成。 评估板接口资源丰富,引出双路网口、双路CAN、双路USB、双路RS485等通信接口&#x…

3、Redis7 十大数据类型(二)

1.8 bitmap(位图)操作命令 SETBIT 设置 格式:setbit 参数1 参数2 参数3 参数1:bitmap名称 参数2:索引 参数3:值( 1 | 0 ) 示例: 将bitmap1的第一个位置的值设为1 s…

常用的flex布局

文章目录 1. flex布局流式布局自动换行2. flex布局流式布局自动换行3. flex横向滚动4. flex 等分5. flex百分比布局6. flex圣杯布局 1. flex布局流式布局自动换行 <!-- 第一种方式: flex布局流式布局自动换行 每行显示3个 --> <div class"box"><div c…

Matlab 主成分分析法

主成分分析 本文将介绍主成分分析(PCA)&#xff0c;主成分分析是一种降维算法&#xff0c;它能将多个指标转换为少数几个主成分&#xff0c;这些主成分是原始变量的线性组合&#xff0c;且彼此之间互不相关&#xff0c;其能反映出原始数据的大部分信息。 一般来说&#xff0c;…

基于SpringBoot+vue的职称评审管理系统设计与实现

博主介绍&#xff1a; 大家好&#xff0c;我是一名在Java圈混迹十余年的程序员&#xff0c;精通Java编程语言&#xff0c;同时也熟练掌握微信小程序、Python和Android等技术&#xff0c;能够为大家提供全方位的技术支持和交流。 我擅长在JavaWeb、SSH、SSM、SpringBoot等框架…

钳式高频电流探头测量电流和提高灵敏度的方法

高频电流探头是一款可以同时测量直流和交流的高频电流探头。高频电流探头采用先进的磁电传感器&#xff0c;通过测试电流所产生的磁场信号实现对电流信号的准确测量&#xff0c;产品坚固耐用&#xff0c;能够大大减少了操作难度&#xff0c;提高测量的准确性。 为了测量数据准确…

Python笔记-1

Python安装问题 1.python是一门解释性的计算机程序语言。 2.IDLE就是我们写Python程序的地方&#xff08;小型的集成开发环境&#xff0c;编辑器&#xff09;。 3.Pycharm是一个大型的集成开发环境&#xff08;IDLE的扩展&#xff0c;不仅可以写&#xff0c;还能管理、调试&am…

树莓派安装DoraClient,连接DoraCloud云桌面

Raspberry Pi&#xff08;树莓派&#xff09; 是为学习计算机编程教育而设计的只有信用卡大小的微型电脑&#xff0c;自问世以来受众多计算机发烧友和创客的追捧&#xff0c;曾经一“派”难求。 DoraCloud是一款多平台的桌面虚拟化管理软件&#xff0c;支持Hyper-V、VMware、P…

Dell Precision 系列工作站指示灯故障诊断参考指南

Dell Precision工作站上用于诊断启动过程中“无法开机自检”故障的各种方法的参考指南 Dell Precision 工作站系统一直以来都有内置诊断指示灯。这些可能是蜂鸣音、显示不同状态和颜色的电源按钮、特定的诊断 LED 指示灯或它们的组合&#xff0c;以便指示在开机自检 &#xff…

Zookeeper集群的特点

一、Zookeeper集群的特点 Zookeeper:一个领导者 (Leader)&#xff0c;多个跟随者 (Follower) 组成的集群集群中只要有半数以上节点存活&#xff0c;Zookeeper集群就能正常服务。所以Zookeeper适合安装奇数台服务器全局数据一致:每个Server保存一份相同的数据副本&#xff0c;C…

vue拿到下拉框el-select的选择项的value和label

此场景分为两种情况 1.单独一个下拉框时 2.el-table每行数据都有下拉框时 这里只介绍第 2 种情况&#xff0c;方法都是一样的 思路&#xff1a; 1.首先选择下拉框事件拿到选择的这行数据scope.row 2.其次去遍历绑定的下拉框数据&#xff0c;使用find&#xff08;&#xff0…

VS中显示矩阵的每个值

VS矩阵值显示 https://github.com/cdcseacave/Visual-Studio-Visualizers#readme 终端中打开输入&#xff1a; git clone https://github.com/cdcseacave/Visual-Studio-Visualizers.git将上面的网址内容下载

PMP考试核心知识点100条汇总(3)

21、项目章程作用 正式宣布项目的存在。 正式任命项目经理&#xff0c;授权其使用组织的资源开展项目活动。 项目章程是由管理层签发的&#xff0c;项目经理是项目章程的执行者。 项目章程所规定的应该是一些比较大的、原则性的问题&#xff0c;通常不会因项目变更而需要对项目…

git常用命令之Merge

5. Merge 场景1&#xff1a;本地分支间合并 命令作用延展阅读git merge dev在master分支执行该命令&#xff0c;则把dev分支内容merge到master分支上自证 场景2&#xff1a;远程release分支合并到本地dev分支 命令作用延展阅读方式1&#xff1a;最省事方式1. git checkout …

C语言-基础语法学习-2 一级指针

目录 指针 C语言指针笔记用指针指向一块地址指针变量指向数组指针变量和常量指针函数指针注意事项 指针 基本概念 指针定义&#xff1a;使用符号声明指针变量&#xff0c;例如int * ptr;。 指针初始化&#xff1a;指针变量可以通过赋值操作初始化为某个变量的地址&#xff0c;…

让你的pytest日志更有序:配置和使用技巧

简介&#xff1a;pytest是一个成熟的全功能的Python测试工具&#xff0c;它覆盖了所有大小和级别的测试需求。从简单的单元测试到复杂的功能测试&#xff0c;都能得心应手。本文将重点介绍如何配置pytest以捕获和存储日志&#xff0c;让你的测试日志更有序。 历史攻略&#xf…

微信小程序页面导航

1.声明式导航 1.1声明式跳转Tab页面 1.1.1配置的Tab页面 1.1.2页面跳转书写 <navigator url"/pages/home/home" open-type"switchTab">跳转首页</navigator> 1.2.3页面展示 1.2声明式跳转到非Tab页面 1.2.1页面跳转代码 <navigator ur…

mediaSoup编译流程(ubuntu20.04不用翻墙,以及踩坑记录)

ubuntu20.04&#xff0c;一定要确保能够ping通github.com因为我们有很多依赖包需要从上面下载 首先安装node.js >16版本 sudo apt-get update curl -sL https://deb.nodesource.com/setup_16.x | sudo -E bash - sudo apt-get install -y nodejs 为node换源 查看node…

数学建模—层次分析法

数模算法1&#xff1a;层次分析法 适用问题&#xff1a;评价类问题&#xff0c;决策&#xff08;方案选择类&#xff09; ** input**&#xff1a;判断矩阵&#xff08;A&#xff09; AHP处理 output:权重&#xff08;得分&#xff09;向量 1.整体导图 2.算法步骤及代码 2.1算…

从关键新闻和最新技术看AI行业发展(2023.5.22-6.22第一期) |【WeThinkIn老实人报】

Rocky Ding WeThinkIn 写在前面 【WeThinkIn老实人报】是WeThinkIn的全新栏目&#xff0c;旨在整理&挖掘AI行业的关键新闻和最新技术&#xff0c;同时Rocky会对这些关键信息进行解读&#xff0c;力求让读者们能从容跟随AI科技潮流。也欢迎大家提出宝贵的优化建议&#xff0…