lorne-tx-core

tx-lcn-core project for Spring Boot

License

License

GroupId

GroupId

com.github.1991wangliang
ArtifactId

ArtifactId

lorne-tx-core
Last Version

Last Version

1.0.2
Release Date

Release Date

Type

Type

jar
Description

Description

lorne-tx-core
tx-lcn-core project for Spring Boot
Project URL

Project URL

https://github.com/1991wangliang/tx-lcn
Source Code Management

Source Code Management

https://github.com/1991wangliang/tx-lcn

Download lorne-tx-core

How to add to project

<!-- https://jarcasting.com/artifacts/com.github.1991wangliang/lorne-tx-core/ -->
<dependency>
    <groupId>com.github.1991wangliang</groupId>
    <artifactId>lorne-tx-core</artifactId>
    <version>1.0.2</version>
</dependency>
// https://jarcasting.com/artifacts/com.github.1991wangliang/lorne-tx-core/
implementation 'com.github.1991wangliang:lorne-tx-core:1.0.2'
// https://jarcasting.com/artifacts/com.github.1991wangliang/lorne-tx-core/
implementation ("com.github.1991wangliang:lorne-tx-core:1.0.2")
'com.github.1991wangliang:lorne-tx-core:jar:1.0.2'
<dependency org="com.github.1991wangliang" name="lorne-tx-core" rev="1.0.2">
  <artifact name="lorne-tx-core" type="jar" />
</dependency>
@Grapes(
@Grab(group='com.github.1991wangliang', module='lorne-tx-core', version='1.0.2')
)
libraryDependencies += "com.github.1991wangliang" % "lorne-tx-core" % "1.0.2"
[com.github.1991wangliang/lorne-tx-core "1.0.2"]

Dependencies

compile (17)

Group / Artifact Type Version
com.github.1991wangliang : lorne_core jar 1.0.0
io.netty : netty-all jar 4.1.12.Final
org.aspectj : aspectjweaver jar 1.8.4
org.aspectj : aspectjrt jar 1.8.4
org.slf4j : slf4j-api jar 1.7.7
org.slf4j : slf4j-log4j12 jar 1.7.7
org.slf4j : slf4j-simple jar 1.7.7
org.slf4j : slf4j-jdk14 jar 1.7.7
javax.servlet : javax.servlet-api jar 3.1.0
org.springframework : spring-context jar 4.3.7.RELEASE
org.springframework : spring-tx jar 4.3.7.RELEASE
com.caucho : hessian jar 4.0.38
com.esotericsoftware : kryo-shaded jar 4.0.0
com.dyuproject.protostuff : protostuff-core jar 1.0.8
com.dyuproject.protostuff : protostuff-runtime jar 1.0.8
com.google.guava : guava jar 19.0
com.alibaba : druid jar 1.0.19

Project Modules

There are no modules declared in this project.

LCN分布式事务框架v3.0 [停止维护,请使用4.0]

"LCN并不生产事务,LCN只是本地事务的搬运工"

3.0 将不再维护,请使用4.0版本。github地址 : https://github.com/codingapi/tx-lcn

框架官网

www.txlcn.org

LCN分布式事务框架v4.0 发布了,详情见框架官网

框架特点

  1. 支持各种基于spring的db框架
  2. 兼容SpringCloud、Dubbo
  3. 使用简单,低依赖,代码完全开源
  4. 基于切面的强一致性事务框架
  5. 高可用,模块可以依赖Dubbo或SpringCloud的集群方式做集群化,TxManager也可以做集群化
  6. 支持本地事务和分布式事务共存
  7. 事务补偿机制,服务故障或挂机再启动时可恢复事务

注意事项

  1. 同一个模块单元下的事务是嵌套的。
  2. 不同事务模块下的事务是独立的。

备注:框架在多个业务模块下操作更新同一个库下的同一张表下的同一条时,将会出现锁表的情况,会导致分布式事务异常,数据会丧失一致性。

方案: 希望开发者在设计模块时避免出现多模块更新操作(insert update delete)同一条数据的情况。

  1. 禁止重名的bean对象。 事务的补偿机制是基于java反射的方式重新执行一次需要补偿的业务。因此执行的时候需要获取到业务的service对象,LCN是基于spring的ApplicationContent的getBean方法获取bean的对象的。因此不允许出现重名对象。

框架的设计原理

文档原理介绍:见 tx-lcn/wiki

视频原理介绍:见 www.txlcn.org

使用示例

引入maven文件,根据框架选择SpringCloud或者Dubbo版本


    <dependency>
        <groupId>com.github.1991wangliang</groupId>
        <artifactId>springcloud-transaction</artifactId>
        <version>1.0.2</version>
    </dependency>
    
    
    <dependency>
        <groupId>com.github.1991wangliang</groupId>
        <artifactId>dubbo-transaction</artifactId>
        <version>1.0.2</version>
    </dependency>

分布式事务发起方:

    @Override
    @TxTransaction
    @Transactional
    public boolean hello() {
        //本地调用
        testDao.save();
        //远程调用方
        boolean res =  test2Service.test();
        //模拟异常
        int v = 100/0;
        return true;
    }
    

分布式事务被调用方(test2Service的业务实现类)

    @Override
    @Transactional
    public boolean test() {
        //本地调用
        testDao.save();
        return true;
    }

如上代码执行完成以后两个模块都将回滚事务。

说明:在使用LCN分布式事务时,只需要将事务的开始方法添加@TxTransaction注解即可。详细见demo教程

关于@TxTransaction 使用说明

@TxTransaction注解是分布式事务的标示。

若存在业务方法:a-b b-c b-d,那么开启分布式事务注解的话,只需要在a方法上添加@TxTransaction即可。

    @TxTransaction
    @Transactional
    public void a(){
        b();
    }

    public void b(){
        c();
        d();
    }

    public void c(){}

    public void d(){}

目录说明

lorne-tx-core 是LCN分布式事务框架的切面核心类库,支持关系型数据库分布式事务

lorne-tx-core-redis 是LCN分布式事务框架对Redis数据库的分布式事务扩展支持

dubbo-transaction 是LCN dubbo分布式事务框架

springcloud-transaction 是LCN springcloud分布式事务框架

tx-manager 是LCN 分布式事务协调器

demo 示例

demo里包含jdbc\hibernate\mybatis版本的demo

dubbo版本的demo dubbo-demo

springcloud版本的demo springcloud-demo

Demo使用视频讲解地址:http://www.txlcn.org/v3/index.html  

技术交流群:554855843

Versions

Version
1.0.2
1.0.0