|
本文参考孙卫琴,杜聚宾所创作的<<Spring Cloud Alibaba微服务开发宝典>>一书,即将出版Seata是一款开源的分布式事务框架,致力于在微服务架构中提供高性能和简单易用的分布式事务管理服务。如图1所示,在Seata框架中,一共有三个角色:- TC(Transaction Coordinator,事务协调者):管理全局和分支事务的状态,驱动分支事务的提交或撤销,从而提交或撤销全局事务。
- TM(Transaction Manager,事务管理器):声明全局事务的边界,包括:开始全局事务、提交或撤销全局事务。
- RM(Resource Manager,资源管理器):管理分支事务处理的资源,与TC交互,向TC注册分支事务并报告分支事务的状态,TC会驱动RM提交或撤销分支事务。
图1 Seata框架中的三个角色
TC是单独部署的服务器,称之为Seata Server,TM和RM是嵌入到微服务中的客户端组件。
在图2中,微服务1调用微服务2,微服务2调用微服务3,共同完成一个分布式的全局事务。该全局事务的生命周期如下:
(1)TM请求TC开启一个全局事务,TC会生成一个XID作为该全局事务的编号,XID会在微服务的调用链路中传播,保证将多个微服务的分支事务关联在一起。
(2)RM请求TC将本地事务注册为全局事务的分支事务,通过全局事务的XID进行关联。
(3)TM请求TC提交或撤销全局事务。
(4)TC驱动RM提交或撤销本地的分支事务。
图2 分布式的全局事务的生命周期
程序猿的技术大观园:www.javathinker.net
|
网站系统异常
系统异常信息 |
Request URL:
http://www.javathinker.net/WEB-INF/lybbs/jsp/topic.jsp?postID=4213&replyID=0&skin=1&saveSkin=true&pages=1&replyNum=
java.lang.NullPointerException
如果你不知道错误发生的原因,请把上面完整的信息提交给本站管理人员。
|
|