dubbo 分布式事务

我觉得事务的管理不应该属于Dubbo框架, 
Dubbo只需实现可被事务管理即可, 
像JDBC和JMS都是可被事务管理的分布式资源, 
Dubbo只要实现相同的可被事务管理的行为,比如可以回滚, 
其它事务的调度,都应该由专门的事务管理器实现。 

在Java中,分布式事务主要的规范是JTA/XA, 
其中:JTA是Java的事务管理器规范, 
XA是工业标准的X/Open CAE规范,可被两阶段提交及回滚的事务资源定义, 
比如某数据库实现了XA规范,则不管是JTA,还是MSDTC,都可以基于同样的行为对该数据库进行事务处理。 

在JTA/XA中,主要有两个扩展点: 

(1) TransactionManager 
JTA事务管理器接口,实现该接口,即可完成对所有XA资源的事务调度,比如BEA的Tuxedo,JBossJTA等。 

(2) XAResource 
XA资源接口,实现该接口,即可被任意TransactionManager调度,比如:JDBC的XAConnection,JMS的XAMQ等。 

而Dubbo的远程服务,也应该是一个XAResource,比如:XAInvoker和XAExporter, 
Dubbo只需在第一次提交时,将请求发到服务提供方进行缓存和写盘, 
在第二次提交时,再基于缓存调用服务的Impl实现, 
当然一些健状性分支流程要考虑清楚。 

JTA/XA的基本原理如下: 

 

1. 用户启动一个事务: 
Java代码   收藏代码
  1. transactionManager.begin();   


2. 事务管理器在当前线程中初始化一个事务实例: 
Java代码   收藏代码
  1. threadLocal.set(new TransactionImpl());  


3. 用户调用JDBC或JMS或Dubbo请求,请求内部初始化一个XAResource实例: 
Java代码   收藏代码
  1. XAResource xaResource = new XAResourceImpl(); // 比如:XAConnection  


4. JDBC或JMS或Dubbo内部从当前线程获取事务: 
Java代码   收藏代码
  1. Transaction transaction = transactionManager.getTransaction(); // 其内部为:threadLocal.get();  


5. 将当前XAResource注册到事务中: 
Java代码   收藏代码
  1. transaction.enlistResource(xaResource);  


6. 用户提交一个事务: 
Java代码   收藏代码
  1. transactionManager.commit(); // 其内部为:getTransaction().commit();  


7. 事务for循环调用所有注册的XAResource的两阶段提交: 
Java代码   收藏代码
  1. Xid xid = new XidImpl();  
  2. for (XAResource xaResource: xaResources) {  
  3. xaResource.prepare(xid);  
  4. xaResource.commit(xid, true);  
  5. xaResource.commit(xid, false);  
  6. }  


8. 当然,还有一些异常流程,比如rollback和forget等。 

举例: 
Java代码   收藏代码
  1. TransactionManager transactionManager = ...; // 从JNDI进行lookup等方式获取  
  2. transactionManager.begin(); // 启动事务  
  3. try {  
  4.     jdbcConn.executeUpdate(sql); // 执行SQL语句,DB写入binlog,但不更新表  
  5.     jmsMQ.send(message); // 发送消息,MQ记录消息,但不进入队列  
  6.     dubboService.invoke(parameters); // 调用远程服务,Provider缓存请求信息,但不执行  
  7.     transactionManager.commit(); // 提交事务,数据库,消息队列,远程服务同时提交  
  8. catch(Throwable t) {  
  9.     transactionManager.rollback(); // 回滚事务,数据库,消息队列,远程服务同时回滚  
  10. }  
http://javatar.iteye.com/blog/981787
  • 0
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
dubbo微服务分布式事务是指在使用dubbo框架进行微服务架构设计时,处理跨多个服务节点间的事务一致性问题的方法。 在分布式系统中,每个服务节点都可以独立运行并处理自己的业务逻辑,因此可能存在多个服务节点相互协作完成一个完整的事务。而分布式事务要求所有参与节点在提交或回滚时保持一致性,即要么都提交,要么都回滚,不能出现部分节点提交,部分节点回滚的情况。 为了解决这个问题,dubbo提供了分布式事务解决方案。首先,可以通过编写一致的接口来规范事务操作的方法。通过在接口上添加@Transactional注解,可以标识该方法为事务处理方法。在方法执行时,dubbo会根据配置的事务管理器对事务进行管理,保证所有事务操作的一致性。 其次,dubbo可以与各种消息中间件集成,如RocketMQ、Kafka等,通过消息队列的方式实现分布式事务的异步提交。使用这种方式,可以先将事务操作记录到消息队列中,然后由消息队列负责保证所有操作的一致性。 另外,dubbo还提供了基于TCC(Try-Confirm-Cancel)模式的分布式事务解决方案。TCC模式通过在事务的预备阶段、确认阶段和取消阶段执行相应的操作,来确保所有参与节点在最终提交或回滚时保持一致性。在dubbo中,可以通过实现Transaction接口来自定义TCC模式的事务管理器,以满足各种业务场景的需求。 总的来说,dubbo微服务框架提供了多种解决方案来处理分布式事务,开发者可以根据具体的业务需求选择合适的方法来保证分布式系统的事务一致性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值