dubbo服务分布式事务话术

 

我们的电商项目中使用到了dubbo、zookeeper的服务化框架,把项目拆分成了订单,帐户,会员,积分,红包等服务,
      

        在Consumer端调用服务的过程中可能会操作多个服务,每个服务可能操作着不同的数据源,这时候就涉及到分布式事务
        的问题。关于分布式事务dubbo框架并没有提供可靠的方案,所以我们还是采用的传统分布式事务的两种解决方案。
        第一种是分成两阶段提交的方式:
        1、请求被发送到事务的协调器上
        2、事务协调器准备一个预处理消息,并写到本地日志。然后把预处理消息发送到事务执行者上
        3、事务执行者收到预处理消息后,执行本机事务,但不commit。成功返回yes,失败返回no。返回前记录日志。
        4、事务协调器收集到所有响应消息,如果执行者全部返回yes,就给所有执行者发送commit消息,执行者接到消息
        后执行commit操作,如果不是全部返回的yes,就给所有执行者发送abort消息,执行者收到消息执行事务放弃操作。
        以上交互过程中记录日志的操作是为了故障恢复,开源软件atomikos可以快速实现上述方案。
        但是这个方案不适合高并发系统,因为通信时间太长,锁定资源时间也长了,效率太低,这是强一致性的场景。
        第二种是使用RabbitMQ消息队列的方式:
        1、业务处理主服务在事务提交之前,向MQ发送请求消息。
        2、业务处理主服务提交事务,向MQ发送确认消息。MQ得到确认消息进行真正的发送。
        3、如果主服务事务提交失败,向MQ发送取消消息,MQ得到取消消息时不会进行发送。
        4、其它服务在收到MQ消息后进行执行,并通知主服务,主服务把MQ中的消息删除。
        这种方式可以保证最终一致性,并且解耦,但是实时性稍差,我们主要使用的就是这种方式。

dubbo服务分布式事务是指在使用dubbo框架进行微服务架构设计时,处理跨多个服务节点间的事务一致性问题的方法。 在分布式系统中,每个服务节点都可以独立运行并处理自己的业务逻辑,因此可能存在多个服务节点相互协作完成一个完整的事务。而分布式事务要求所有参与节点在提交或回滚时保持一致性,即要么都提交,要么都回滚,不能出现部分节点提交,部分节点回滚的情况。 为了解决这个问题,dubbo提供了分布式事务解决方案。首先,可以通过编写一致的接口来规范事务操作的方法。通过在接口上添加@Transactional注解,可以标识该方法为事务处理方法。在方法执行时,dubbo会根据配置的事务管理器对事务进行管理,保证所有事务操作的一致性。 其次,dubbo可以与各种消息中间件集成,如RocketMQ、Kafka等,通过消息队列的方式实现分布式事务的异步提交。使用这种方式,可以先将事务操作记录到消息队列中,然后由消息队列负责保证所有操作的一致性。 另外,dubbo还提供了基于TCC(Try-Confirm-Cancel)模式的分布式事务解决方案。TCC模式通过在事务的预备阶段、确认阶段和取消阶段执行相应的操作,来确保所有参与节点在最终提交或回滚时保持一致性。在dubbo中,可以通过实现Transaction接口来自定义TCC模式的事务管理器,以满足各种业务场景的需求。 总的来说,dubbo服务框架提供了多种解决方案来处理分布式事务,开发者可以根据具体的业务需求选择合适的方法来保证分布式系统的事务一致性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值