微服务分布式事务落地方案

我认为微服务,应该有如下特征:1、专注某个领域的服务提供   2、独立JVM隔离  3、独立资源管理    4、可拔插

1、微服务实现

其实很简单,用dubbo就可以轻易实现不同service project 独立部署,实现高可用,高性能和高扩展性的API。其实这个实现方式太多了,没什么难度,难就难在如何实现微服务分布后的分布事务。这个是很多人避而不谈的,下面我们着重探讨一下。


2、分布事务实现

先看看下图,主要表述了以下几个东西:

1、web project(controller类)通过jetty容器分布部署,通过rpc(dubbo实现)方式远程调用service api。

2、微服务service api通过dubbo进行集群。

3、微服务service api有自己独立的数据库资源,独立管理。如果是某些业务涉及垮库写操作,可以通过混合事务实现。

说到事务,有必要对事务进行分类,以便分而治之。以比较典型的电商业务为例:

1)强一致性事务

场景:下订单,扣库存,必须实时保持一致。

对于要求较高的实时性业务,只要保证垮库操作在同一个虚拟机内完成,即可最大限度的保证强

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值