TX-LCN分布式事务Demo实战

2024-05-02 10:38
文章标签 实战 分布式 事务 demo tx lcn

本文主要是介绍TX-LCN分布式事务Demo实战,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. TX-LCN分布式事务Demo实战

1.1. 原理介绍

1.1.1. 事务控制原理

  1. TX-LCN由两大模块组成, TxClient、TxManager,TxClient作为模块的依赖框架,提供TX-LCN的标准支持,TxManager作为分布式事务的控制放。事务发起方或者参与反都由TxClient端来控制。(简单来说就是单独部署一套TxManager模块来实现事务管理,TxClient就是我们自己的服务系统
  2. 原理图如下:
    1

1.1.2. LCN事务模式

1.1.2.1. 原理介绍
  1. LCN模式是通过代理Connection的方式实现对本地事务的操作,然后在由TxManager统一协调控制事务。当本地事务提交回滚或者关闭连接时将会执行假操作,该代理的连接将由LCN连接池管理。
1.1.2.2. 模式特点
  1. 该模式对代码的嵌入性为低
  2. 该模式仅限于本地存在连接对象且可通过连接对象控制事务的模块。
  3. 该模式下的事务提交与回滚是由本地事务方控制,对于数据一致性上有较高的保障
  4. 该模式缺陷在于代理的连接需要随事务发起方一共释放连接,增加了连接占用的时间

1.1.3. TCC事务模式

1.1.3.1. 原理介绍
  1. TCC事务机制相对于传统事务机制(X/Open XA Two-Phase-Commit),其特征在于它不依赖资源管理器(RM)对XA的支持,而是通过对(由业务系统提供的)业务逻辑的调度来实现分布式事务。主要由三步操作,Try: 尝试执行业务、 Confirm:确认执行业务、 Cancel: 取消执行业务
1.1.3.2. 模式特点
  1. 该模式对代码的嵌入性高,要求每个业务需要写三种步骤的操作。
  2. 该模式对有无本地事务控制都可以支持使用面广。
  3. 数据一致性控制几乎完全由开发者控制,对业务开发难度要求高

1.1.4. TXC事务模式

1.1.4.1. 原理介绍
  1. TXC模式命名来源于阿里云的GTS,实现原理是在执行SQL之前,先查询SQL的影响数据保存起来然后再执行业务。当需要回滚的时候就采用这些记录数据回滚事务
1.1.4.2. 模式特点
  1. 该模式同样对代码的嵌入性低
  2. 该模式仅限于对支持SQL方式的模块支持。
  3. 该模式由于每次执行SQL之前需要先查询影响数据,因此相比LCN模式消耗资源与时间要多
  4. 该模式不会占用数据库的连接资源

1.2. 快速开始

1.2.1. 吐槽

  1. 坑点一:不要相信官方网站上的的快速开始和示例,不知道是多久以前的了,我捣鼓了很久,下下来的代码缺斤少两的,打包了源代码也满足不了这示例代码的需求
  2. 坑点二:不要直接使用源代码的tx-manager,肯定仍旧缺少配置,或者和示例代码版本不一致
  3. 让我来个完整的能运行的示例Demo。 ps:也都是从官方github拉的
  4. 我演示的是4.0的demo,目前也够用了,5.0的demo我是运行不起来,缺少jar包,有路过的大神知道怎么搞,求教

1.2.2. tx-manager

https://pan.baidu.com/s/1cLKAeE#list/path=%2Fsharelink974324822-625872931897976%2Ftx-manager&parentPath=%2Fsharelink974324822-625872931897976

  1. 这个tx-manager直接从官方提供的网盘下载,我下的4.1版本的
  2. 修改配置文件,eureka和redis都整成自己的
  3. 直接java -jar tx-manager.jar 运行起来就可以了

1.2.3. SpringCloud Demo

https://github.com/codingapi/springcloud-lcn-demo

  1. 上述地址为4.0版本的demo,经试验可以使用
  2. 我用mybatis-demo这个包做的试验,里面两个module,分别修改application.properties,只需要修改数据库mysql和eureka地址就行
  3. 当然数据库别忘了建,建个test库,新建下列表用于测试
USE test;DROP TABLE IF EXISTS `t_test`;CREATE TABLE `t_test` (`id` int(11) unsigned NOT NULL AUTO_INCREMENT,`name` varchar(50) DEFAULT NULL,PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

1.3. 使用总结

  1. 如果需要在自己的项目使用LCN只需要两步
    1. 引入pom
    <lcn.last.version>4.1.0</lcn.last.version><dependency><groupId>com.codingapi</groupId><artifactId>transaction-springcloud</artifactId><version>${lcn.last.version}</version><exclusions><exclusion><groupId>org.slf4j</groupId><artifactId>*</artifactId></exclusion></exclusions>
    </dependency><dependency><groupId>com.codingapi</groupId><artifactId>tx-plugins-db</artifactId><version>${lcn.last.version}</version><exclusions><exclusion><groupId>org.slf4j</groupId><artifactId>*</artifactId></exclusion></exclusions>
    </dependency>
    1. 加一个注解,譬如
    @Override
    @TxTransaction(isStart = true)
    @Transactionalpublic int save() {int rs2 = demo2Client.save();int rs1 = testMapper.save("mybatis-hello-1");
    //        int rs22 = demo2Client.save();//        int v = 100/0;return rs1+rs2;
    }
    加上 @TxTransaction(isStart = true) 表示事务开始,在走完整个流程以前,事务都会由tx-manager来协调

1.4. 4.0与5.0版本

  1. 5.0刚出来没多久,也就1月份开始大量提交,并已经交由codingApi团队开发维护,对5.0的使用,或许还要经历些时间的磨练
  2. 对上述这个注解,在4.0我找到原代码是这样的
/*** Created by lorne on 2017/6/26.*/
@Target({ElementType.METHOD, ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Inherited
@Documented
public @interface TxTransaction {/*** 是否LCN事务发起方* @return true 是:是发起方 false 否:是参与方*/boolean isStart() default false;/*** 回滚异常* @return*/Class<? extends Throwable>[] rollbackFor() default {};/*** 不回滚异常* @return*/Class<? extends Throwable>[] noRollbackFor() default {};}
  1. 在5.0我同样找到了源代码,是这样的
/*** Created by lorne on 2017/6/26.*/
@Target({ElementType.METHOD, ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Inherited
@Documented
public @interface TxTransaction {/*** 事务模式 transaction type** @return lcn, tcc, txc* @see Transactions*/String type() default Transactions.LCN;/*** 分布式事务传播行为** @return 传播行为* @see DTXPropagation*/DTXPropagation propagation() default DTXPropagation.REQUIRED;
}
  1. 很明显,注解使用和实现都完全变了,4.0和5.0明显不能兼容了。
  2. 通过新版本的一堆注解也可以看出来,4.0版本只支持LCN模式,想要尝试TCC和TXC的,把5.0的Demo去跑通吧
    751560-20190131153056910-494160822.png

1.5. 官方网站

https://www.txlcn.org/zh-cn/docs/start.html

这篇关于TX-LCN分布式事务Demo实战的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/954063

相关文章

Golang使用minio替代文件系统的实战教程

《Golang使用minio替代文件系统的实战教程》本文讨论项目开发中直接文件系统的限制或不足,接着介绍Minio对象存储的优势,同时给出Golang的实际示例代码,包括初始化客户端、读取minio对... 目录文件系统 vs Minio文件系统不足:对象存储:miniogolang连接Minio配置Min

Golang使用etcd构建分布式锁的示例分享

《Golang使用etcd构建分布式锁的示例分享》在本教程中,我们将学习如何使用Go和etcd构建分布式锁系统,分布式锁系统对于管理对分布式系统中共享资源的并发访问至关重要,它有助于维护一致性,防止竞... 目录引言环境准备新建Go项目实现加锁和解锁功能测试分布式锁重构实现失败重试总结引言我们将使用Go作

Node.js 中 http 模块的深度剖析与实战应用小结

《Node.js中http模块的深度剖析与实战应用小结》本文详细介绍了Node.js中的http模块,从创建HTTP服务器、处理请求与响应,到获取请求参数,每个环节都通过代码示例进行解析,旨在帮... 目录Node.js 中 http 模块的深度剖析与实战应用一、引言二、创建 HTTP 服务器:基石搭建(一

Redis分布式锁使用及说明

《Redis分布式锁使用及说明》本文总结了Redis和Zookeeper在高可用性和高一致性场景下的应用,并详细介绍了Redis的分布式锁实现方式,包括使用Lua脚本和续期机制,最后,提到了RedLo... 目录Redis分布式锁加锁方式怎么会解错锁?举个小案例吧解锁方式续期总结Redis分布式锁如果追求

SpringBoot嵌套事务详解及失效解决方案

《SpringBoot嵌套事务详解及失效解决方案》在复杂的业务场景中,嵌套事务可以帮助我们更加精细地控制数据的一致性,然而,在SpringBoot中,如果嵌套事务的配置不当,可能会导致事务不生效的问题... 目录什么是嵌套事务?嵌套事务失效的原因核心问题:嵌套事务的解决方案方案一:将嵌套事务方法提取到独立类

网页解析 lxml 库--实战

lxml库使用流程 lxml 是 Python 的第三方解析库,完全使用 Python 语言编写,它对 XPath表达式提供了良好的支 持,因此能够了高效地解析 HTML/XML 文档。本节讲解如何通过 lxml 库解析 HTML 文档。 pip install lxml lxm| 库提供了一个 etree 模块,该模块专门用来解析 HTML/XML 文档,下面来介绍一下 lxml 库

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

滚雪球学Java(87):Java事务处理:JDBC的ACID属性与实战技巧!真有两下子!

咦咦咦,各位小可爱,我是你们的好伙伴——bug菌,今天又来给大家普及Java SE啦,别躲起来啊,听我讲干货还不快点赞,赞多了我就有动力讲得更嗨啦!所以呀,养成先点赞后阅读的好习惯,别被干货淹没了哦~ 🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,助你一臂之力,带你早日登顶🚀,欢迎大家关注&&收藏!持续更新中,up!up!up!! 环境说明:Windows 10

集中式版本控制与分布式版本控制——Git 学习笔记01

什么是版本控制 如果你用 Microsoft Word 写过东西,那你八成会有这样的经历: 想删除一段文字,又怕将来这段文字有用,怎么办呢?有一个办法,先把当前文件“另存为”一个文件,然后继续改,改到某个程度,再“另存为”一个文件。就这样改着、存着……最后你的 Word 文档变成了这样: 过了几天,你想找回被删除的文字,但是已经记不清保存在哪个文件了,只能挨个去找。真麻烦,眼睛都花了。看