原文地址:http://原文地址:https://github.com/1991wangliang/transaction

基于Dubbo的分布式事务框架(LCN)

该框架依赖Redis/dubbo/txManager服务。依赖第三方框架lorne_core

原理与功能

基于对spring tx PlatformTransactionManager的本地模块事务控制从而达到全局控制事务的目的。该框架兼容任何依赖PlatformTransactionManager的DB框架。利用三阶段提交的方式来确保事务的一致性,支持本地事务和分布式事务框架共存,当方法进入的是本地事务方法,框架将不做任何分布式事务处理。当需要用到分布式事务的时候只需要在方法上添加分布式事务的注解即可。框架由于基于Spring本地事务做的封装,基本支持依赖spring的所有db框架。并在帖子底部提供了对springjdbc/hibernate/mybatis的演示demo。

该框架在设计时就考虑到大型分布式的应用场景,因此框架支持对于dubbo单个模块的集群化。并且TxManager也支持集群化。

框架基于三阶段提交:

锁定事务单元

确认事务模块状态

通知事务

关于LCN框架的详细设计请见txManager说明

框架使用教程

需要先部署redis服务。

部署TxManager全局事务协调管理器。

本地项目依赖transaction库.

maven仓库地址

<repositories>

<repository>

<id>lorne</id>

<url>https://1991wangliang.github.io/repository</url>

</repository>

</repositories>

maven transaction 配置

<dependency>

<groupId>com.lorne.tx</groupId>

<artifactId>transaction</artifactId>

<version>1.0.0.RELEASE</version>

</dependency>

配置dubbo服务

<dubbo:application name="tx-transaction-test"   />

<!--所有参与分布式事务的模块以及TxManager都必须要在同一个服务下-->

<dubbo:registry protocol="zookeeper" address="127.0.0.1:2181" />

<!--依赖TxManager服务-->

<dubbo:reference timeout="3000" interface="com.lorne.tx.mq.service.MQTxManagerService" id="managerService" />

<dubbo:protocol accesslog="true" name="dubbo" port="20882" />

<!--所有需要分布式事务的模块也都必须对外提供服务-->

<!--1. 用户自定义的服务-->

<dubbo:service interface="com.demo.service.MQTestService" ref="testService"  />

<bean id="testService" class="com.demo.service.impl.MQTestServiceImpl"   />

<!--2. 当用户没有需要对外提供的服务时-->

<!--<dubbo:service interface="com.lorne.tx.mq.service.MQTransactionService" ref="transactionService"  />-->

<!--<bean id="transactionService" class="com.lorne.tx.mq.service.impl.MQTransactionServiceImpl"   />-->

若用户是自定义的服务,则服务必须要实现MQTransactionService接口如下:

public interface MQTestService extends MQTransactionService{

String test(String name);

}

MQTransactionService的实现:第一种方式

@Service

public class MQTestServiceImpl extends MQTransactionServiceImpl implements MQTestService {

@Override

public String test(String name) {

//todo 用户业务处理

return "";

}

}

MQTransactionService的实现:第二种方式

@Service

public class MQTestServiceImpl implements MQTestService {

@Autowired

private MQTransactionService transactionService;

@Override

public boolean notify(String kid, boolean state) {

return transactionService.notify(kid, state);

}

@Override

public boolean checkRollback(String kid) {

return transactionService.checkRollback(kid);

}

@Override

public String test(String name) {

//todo 用户业务处理

return "";

}

}

分布式事务的切面配置

<!--本地事务manager  -->

<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">

<property name="dataSource" ref="dataSource"/>

</bean>

<!--本地事务切面 -->

<tx:annotation-driven transaction-manager="transactionManager"/>

<!--切面 advice 定义-->

<tx:advice id="txAdvice">

<tx:attributes>

<tx:method name="get*" read-only="true"  />

<tx:method name="find*" read-only="true"/>

<tx:method name="load*" read-only="true"/>

<tx:method name="query*" read-only="true"/>

<tx:method name="select*" read-only="true"/>

<tx:method name="*" rollback-for="com.le.core.framework.exception.LEException"/>

</tx:attributes>

</tx:advice>

<!--分布式事务拦截器-->

<bean id="txTransactionInterceptor" class="com.lorne.tx.interceptor.TxManagerInterceptor"/>

<aop:config>

<aop:pointcut id="allManagerMethod" expression="execution(* com.**.service.impl.*Impl.*(..))"/>

<!--本地事务拦截-->

<aop:advisor  order="100" advice-ref="txAdvice" pointcut-ref="allManagerMethod"/>

<!--分布式事务拦截-->

<aop:advisor  order="10" advice-ref="txTransactionInterceptor" pointcut-ref="allManagerMethod"/>

</aop:config>

分布式事务注解(@TxTransaction)

@Override

@TxTransaction

public String test() {

//todo 业务处理

return "";

}

关于@TxTransaction的补充说明: 当添加事务注解时方法将开启分布式事务处理方式。当尽当开始方法是分布式事务方法时才进入分布式事务处理逻辑。 若存在业务方法A调用了业务方法B,当分布式事务注解添加在A上,那么整个A方法将被分布式事务所管理,若注解添加在B上,当调用A时将不会被启用分布式事务,尽当业务启动时的方法添加分布式事务注解时方可开启分布式事务注解。

演示demo:

spring-jdbc版本: transaction_demo1 transaction_demo2

transaction_demo1是发起方,transaction_demo2是被调用方。

hibernate版本:

transaction_hibernate_demo1 transaction_hibernate_demo2

transaction_hibernate_demo1是发起方,transaction_hibernate_demo2是被调用方。

mybatis版本:

transaction_mybatis_demo1 transaction_mybatis_demo2

transaction_mybatis_demo1是发起方,transaction_mybatis_demo2是被调用方。

参考更多免费教程请加入Dubbo技术交流:548209960

Java高并发高可用架构:632103578

基于Dubbo的分布式事务框架(LCN)的更多相关文章

  1. tcc分布式事务框架解析

    前言碎语 楼主之前推荐过2pc的分布式事务框架LCN.今天来详细聊聊TCC事务协议. 2pc实现:https://github.com/codingapi/tx-lcn tcc实现:https://g ...

  2. 终于跑通分布式事务框架tcc-transaction的示例项目

    1.背景 前段时间在看项目代码的时候,发现有些接口的流程比较长,在各个服务里面都有通过数据库事务保证数据的一致性,但是在上游的controller层并没有对一致性做保证. 网上查了下,还没找到基于Go ...

  3. TX-LCN 分布式事务框架

    第十章 TX-LCN 分布式事务框架 (Spring Cloud 高级) 一. 什么是分布式事务 分布式事务是指事务的参与者.支持事务的服务器.资源服务器以及事务管理器分别位 于不同的分布式系统的不同 ...

  4. 分布式事务框架-Litx补偿事务框架源码解析

    前言 之前某段时间在研究分布式事务过程中,对实现原理比较好奇,于是去Gitee上找了几个人气比较高的框架进行学习,其中印象深刻的有Litx,因为Litx源码不多,且都是基于Spring和Dubbo底层 ...

  5. 基于dubbo的分布式项目实例应用

    本文主要学习dubbo服务的启动检查.集群容错.服务均衡.线程模型.直连提供者.只定阅.只注册等知识点,希望通过实例演示进一步理解和掌握这些知识点. 启动检查 Dubbo缺省会在启动消费者时检查依赖的 ...

  6. 基于 dubbo 的分布式架构

    前言 现在越来越多的互联网公司还是将自己公司的项目进行服务化,这确实是今后项目开发的一个趋势,就这个点再凭借之前的 SSM 项目来让第一次接触的同学能快速上手. 浅谈分布式架构 分布式架构单看这个名字 ...

  7. 分布式事务、多数据源、分库分表中间件之spring boot基于Atomikos+XADataSource分布式事务配置(100%纯动态)

    本文描述spring boot基于Atomikos+DruidXADataSource分布式事务配置(100%纯动态),也就是增加.减少数据源只需要修改application.properties文件 ...

  8. 分布式事务框架&解决方案参考

    两种开源解决方案框架介绍: https://blog.csdn.net/zyndev/article/details/79604395#_97 LCN: https://www.jianshu.com ...

  9. Dubbo 支持分布式事务吗?

    目前暂时不支持,可与通过 tcc-transaction 框架实现 介绍:tcc-transaction 是开源的 TCC 补偿性分布式事务框架 Git 地址:https://github.com/c ...

随机推荐

  1. Struts2之2.5.10.1HelloWorld

    Struts2.5.10.1是目前为止最新的版本,struts2建议持续跟进,理由大家都懂.好了,下面步入正题. 基于struts2.5.10.1建立一个HelloWorld,基于注解的哈! 工具:e ...

  2. 转:MySQL表名不区分大小写

    在LINUX下调一个程序老说找不到表,但是我明明是建了表的,在MYSQL的命令行下也可以查到,为什么程序就找不到表呢? 一.linux中mysql大小写详情: 1.数据库名严格区分大小写 2.表名严格 ...

  3. MySql5.7环境搭建

    1. 安装mysql的linux系统 [root@grewan ~]# cat /etc/redhat-release CentOS release 6.7 (Final) [root@grewan ...

  4. 自己实现的一个简单的EF框架(反射实现)

    我实现了一个简单的EF框架,主要用于操纵数据库.实现了对数据库的基本操纵--CRUD 这是项目结构 这是一个 core 下的 DLL 写了一个数据库工厂,用于执行sql语句.调用sql语句工厂 写了一 ...

  5. trap-接收信号_采取行动

    trap命令用于指定在接收到信号后将要采取的动作,常见的用途是在脚本程序被中断时完成清理工作. kill和trap等都可以看到信号编号及其关联的名称. "信号"是指那些被异步发送到 ...

  6. 看透SpringMVC源代码分析与实践 Markdown记录

    kantouspringmvc 看透SpringMVC中文版电子书,使用Markdown语法记录学习<看透SpringMVC>的内容,方便自己整理知识,并在原作者写作的基础上添加自己的理解 ...

  7. 元类(meta class)

    元类(meta class),这个名字想必很多人都听过,网上也有很多关于元类的介绍,今天我就按照自己这两天的理解来简单探讨一下这个玩意,有误之处还望指出. 首先,下载objc源码,源码地址:https ...

  8. Spring MVC动态切换数据源(多数据库类型)

    最近由于项目需求,需要将Sql Server 和 Mysql 两种数据库整合到一个项目,项目的用到的框架是SSM. 因此尝试了利用AOP切面来切每次执行的Servcie方法,根据Service所在的包 ...

  9. OpenStack dashboard界面操作 实现登陆虚拟机并通信

    1.创建项目,点击"创建项目" (1).填写项目信息 (2).添加与之关联的项目成员 (3).点击"配额",为用户在平台上分配一个操作的空间,便于用户创建网络, ...

  10. mxnet:结合R与GPU加速深度学习(转)

    近年来,深度学习可谓是机器学习方向的明星概念,不同的模型分别在图像处理与自然语言处理等任务中取得了前所未有的好成绩.在实际的应用中,大家除了关心模型的准确度,还常常希望能比较快速地完成模型的训练.一个 ...