面试--分布式

分布式事务解决方案

XA规范:分布式事务规范,定义分布式事务模型。

四个角色:事务管理器(协调者TM),资源管理器(参与者RM),应用程序AP,通信资源管理器CRM

全局事务:一个横跨多个数据库的事务,要么全部提交、要么全部回滚

1、jta事务时java对XA规范的实现,对应JDBC的单库事务。
在这里插入图片描述

2、TCC(补偿事务):Try,confim,Cancel

针对每个操作,都注册一个对应的确认和补偿操作

Try操作做业务检查及资源预留,Comfirm做业务确认操作,Cancel实现一个与Try相反的操作即回滚操作。TM首先发起所以的分支事务的try操作,任何一个分支事务的try操作执行失败,TM将会发起所有分支事务的Cancel操作,若try操作全部成功,TM会发起所有分支事务的Confirm操作,其中Confirm/Cancel操作若执行失败,TM会进行重试。

TCC模型对业务的浸入性较强,改造的难度比较大,每个操作都需要try,Confirm,cancel三个接口实现Confirm和cancel接口还必须实现幂等性。

3、消息队列的事务消息:

  • 发送prepare消息到消息中间件
  • 发送成功后,执行本地事务
  • 如果事务执行成功,则commit,消息中间件将消息下发至消息端(commit前,消息不会被消费)
  • 如果事务执行失败,这回滚,消息中间件将这条prepare消息删除
  • 消息端收到消息进行消费,如果消费失败,则不断重试。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值