news 2026/5/9 6:31:51

5、Seata

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
5、Seata

分布式事务 产生原因:

  • 由于service相互分离,没有协同,相互感知各自的状态,导致事务回滚出现问题

原理

  • RM(Resource Manager):用于直接执行本地事务的提交和回滚。
  • TM(Transaction Manager):TM是分布式事务的核心管理者。比如现在我们需要在借阅服务中开启全局事务,来让其自身、图书服务、用户服务都参与进来,也就是说一般全局事务发起者就是TM。
  • TC(Transaction Manager)这个就是我们的Seata服务器,用于全局控制,比如在XA模式下就是一个协调者的角色,而一个分布式事务的启动就是由TM向TC发起请求,TC再来与其他的RM进行协调操作。

TM请求TC开启一个全局事务,TC会生成一个XID作为该全局事务的编号,XID会在微服务的调用链路中传播,保证将多个微服务的子事务关联在一起;RM请求TC将本地事务注册为全局事务的分支事务,通过全局事务的XID进行关联;TM请求TC告诉XID对应的全局事务是进行提交还是回滚;TC驱动RM将XID对应的自己的本地事务进行提交还是回滚;


一、安裝

各个服务作为Seate的客户端,只需要导入依赖即可:

<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-seata</artifactId></dependency>

然后添加配置:

seata:service:vgroup-mapping:# 这里需要对事务组做映射,默认的分组名为 应用名称-seata-service-group,将其映射到default集群# 这个很关键,一定要配置对,不然会找不到服务bookservice-seata-service-group:defaultgrouplist:default:localhost:8868

二、使用

开启分布式事务的方法上添加@GlobalTransactional注解:

@GlobalTransactional@OverridepublicbooleandoBorrow(intuid,intbid)

Seata会分析修改数据的sql,同时生成对应的反向回滚SQL,这个回滚记录会存放在undo_log 表中。所以要求每一个Client 都有一个对应的undo_log表(也就是说每个服务连接的数据库都需要创建这样一个表,这里由于我们三个服务都用的同一个数据库,所以说就只用在这个数据库中创建undo_log表即可),表SQL定义如下:

CREATETABLE`undo_log`(`id`BIGINT(20)NOTNULLAUTO_INCREMENT,`branch_id`BIGINT(20)NOTNULL,`xid`VARCHAR(100)NOTNULL,`context`VARCHAR(128)NOTNULL,`rollback_info`LONGBLOBNOTNULL,`log_status`INT(11)NOTNULL,`log_created`DATETIMENOTNULL,`log_modified`DATETIMENOTNULL,`ext`VARCHAR(100)DEFAULTNULL,PRIMARYKEY(`id`),UNIQUEKEY`ux_undo_log`(`xid`,`branch_id`))ENGINE=InnoDBAUTO_INCREMENT=1DEFAULTCHARSET=utf8;
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/8 16:38:37

资源利用率下降30%?私有化Dify监控告警机制这样优化,稳了!

第一章&#xff1a;私有化 Dify 资源监控的背景与挑战在企业级 AI 应用部署中&#xff0c;Dify 作为支持可视化编排与模型集成的低代码平台&#xff0c;越来越多地被部署于私有化环境中。这种部署模式赋予企业更高的数据控制权与系统安全性&#xff0c;但同时也带来了对资源使用…

作者头像 李华
网站建设 2026/5/8 16:38:37

Spring AI Alibaba - 企业级AI应用开发框架

Spring AI Alibaba - 企业级AI应用开发框架 相关链接资源 Github&#xff1a;https://github.com/alibaba/spring-ai-alibaba 官网&#xff1a;https://java2ai.com 官方文档&#xff1a;https://java2ai.com/docs/1.0.0.2/get-started/chatbot 示例仓库&#xff1a;https://gi…

作者头像 李华
网站建设 2026/5/8 16:38:57

揭秘Dify模型私有化部署难题:如何实现秒级加载与稳定运行

第一章&#xff1a;Dify模型私有化部署的核心挑战在企业级AI应用中&#xff0c;将Dify模型进行私有化部署已成为保障数据安全与合规性的关键路径。然而&#xff0c;这一过程面临多重技术与架构层面的挑战&#xff0c;涉及环境依赖管理、资源调度、权限控制及持续集成等多个维度…

作者头像 李华
网站建设 2026/5/8 16:38:05

Docker + Vercel AI SDK环境变量配置终极方案(附完整CI/CD流程代码)

第一章&#xff1a;Docker 与 Vercel AI SDK 的环境变量概述在现代全栈应用开发中&#xff0c;Docker 和 Vercel AI SDK 的结合为开发者提供了高效、可移植的部署方案与强大的生成式 AI 能力。环境变量作为连接本地开发与生产部署的关键桥梁&#xff0c;承担着配置管理、密钥隔…

作者头像 李华
网站建设 2026/5/9 0:33:47

10 个专科生降AIGC工具推荐,AI写作优化神器

10 个专科生降AIGC工具推荐&#xff0c;AI写作优化神器 论文写作的困境&#xff1a;时间、重复率与降重的三重挑战 对于专科生来说&#xff0c;论文写作从来不是一件轻松的事。从选题到文献综述&#xff0c;再到撰写和修改&#xff0c;每一个环节都充满了挑战。尤其是在任务书阶…

作者头像 李华