这是一道关于Seata的Java面试题

开发 前端
从这四种模型中不难看出,在不同的业务场景中,我们可以使用 Seata 的不同事务模型来解决不同业务场景中的分布式事务问题,因此我们可以认为 Seata是一个一站式的分布式事务解决方案。

Seata在大厂也是属于高频的面试题,有一位3年工作经验的小伙伴被问到一道这样的面试题,说“谈谈你对Seata的理解”。那么,今天我给大家来聊一聊。

另外,我花了很长时间,准备了一份500页的PDF面试资料文档和一份10W字的Java总结面试题和答案,

图片

1、Seata是什么

在微服务架构下,由于数据库和应用服务的拆分,导致原本一个事务单元中的多个 DML 操作,变成了跨进程或者跨数据库的多个事务单元的多个 DML 操作,而传统的数据库事务无法解决这类的问题,所以就引出了分布式事务的概念。

ENTER TITLE

图片

分布式事务本质上要解决的就是跨网络节点的多个事务的数据一致性问题,业内常见的解决方法有两种:

ENTER TITLE

图片

1、强一致性

图片

就是所有的事务参与者要么全部成功,要么全部失败,全局事务协调者需要知道每个事务参与者的执行状态,再根据状态来决定数据的提交或者回滚!

图片

2、最终一致性,也叫弱一致性

图片

也就是多个网络节点的数据允许出现不一致的情况,但是在最终的某个时间点会达成数据一致。

图片

基于 CAP 定理我们可以知道,强一致性方案对于应用的性能和可用性会有影响,所以对于数据一致性要求不高的场景,就会采用最终一致性算法。

在分布式事务的实现上,对于强一致性,我们可以通过基于 XA 协议下的二阶段提交来实现,对于弱一致性,可以基于 TCC 事务模型、可靠性消息模型等方案来实现。市面上有很多针对这些理论模型实现的分布式事务框架,我们可以在应用中集成这些框架来实现分布式事务。而 Seata 就是其中一种,它是阿里开源的分布式事务解决方案,提供了高性能且简单易用的分布式事务服务。

1、Seata事务模式

图片

Seata 中封装了四种分布式事务模式,分别是:AT模式、TCC 模式、Saga 模式和XA 模式。下面我给大家详细介绍一下:

第1种:AT 模式,是一种基于本地事务+二阶段协议来实现的最终数据一致性方案,也是Seata 默认的解决方案

图片

第2种:TCC 模式,TCC 事务是 Try、Confirm、Cancel 三个词语的缩写,简单理解就是把一个完整的业务逻辑拆分成三个阶段,然后通过事务管理器在业务逻辑层面根据每个分支事务的执行情况分别调用该业务的 Confirm 或者 Cacel 方法。

图片

第3种:Saga 模式,Saga 模式是 SEATA 提供的长事务解决方案,在 Saga 模式中,业务流程中每个参与者都提交本地事务,当出现某一个参与者失败则补偿前面已经成功的参与者。

图片

第4种:XA 模式,XA 可以认为是一种强一致性的事务解决方法,它利用事务资源(数据库、消息服务等)对 XA 协议的支持,以 XA 协议的机制来管理分支事务的一种事务模式。

图片

从这四种模型中不难看出,在不同的业务场景中,我们可以使用 Seata 的不同事务模型来解决不同业务场景中的分布式事务问题,因此我们可以认为 Seata是一个一站式的分布式事务解决方案。

以上就是我对Seata的理解!面试的时候经常会遇到这种宽泛的面试题,一般就是问“谈谈你对XX的理解”。遇到这类面试题,先不用慌,我告诉大家一个回答的思路。可以按照技术发展的逻辑,就是先在自己的大脑中的建立一个知识索引,然后基于索引来定位你的知识。

图片

比如,对于这类问题,一般可以建立一个这样的思维逻辑:

它是什么?

它能解决什么问题?

它有哪些特点和优势?

它的核心原理是什么?

为什么它能解决这类问题?

大家对照这个逻辑去回答这类面试题,是不是感觉思路异常更清晰呢?

最后,我把之前分享的资料全部整理成了文字,希望能够以此来提高各位粉丝的通过率。 0%

图片

责任编辑:武晓燕 来源: Tom弹架构
相关推荐

2018-03-06 15:30:47

Java面试题

2022-04-08 07:52:17

CSS面试题HTML

2024-10-11 17:09:27

2011-05-23 11:27:32

面试题面试java

2015-09-02 14:09:19

面试题程序设计

2009-08-11 10:12:07

C#算法

2009-08-11 14:59:57

一道面试题C#算法

2021-05-31 07:55:44

smartRepeatJavaScript函数

2009-08-11 15:09:44

一道面试题C#算法

2017-11-21 12:15:27

数据库面试题SQL

2023-08-01 08:10:46

内存缓存

2021-03-16 05:44:26

JVM面试题运行时数据

2021-10-28 11:40:58

回文链表面试题数据结构

2022-02-08 18:09:20

JS引擎解析器

2011-03-02 10:58:16

SQL server入门面试题

2017-03-10 09:33:16

JavaScript类型

2017-09-13 07:15:10

Python读写文件函数

2021-03-27 10:59:45

JavaScript开发代码

2011-06-14 09:12:03

JavaScript

2018-02-01 16:26:44

面试题static变量
点赞
收藏

51CTO技术栈公众号