Tx-LCN源码通读-Lcn模式(1)

本文深入探讨了分布式事务中的LCN模式,包括其与TCC、TXC模式的区别。LCN主要由TC和TM组成,其中TC作为客户端的事务代理,TM管控事务生命周期。文章详细阐述了TC的初始化过程、事务生命周期和核心功能,同时指出LCN在数据最终一致性方面的局限性。
摘要由CSDN通过智能技术生成

目前主流的分布式事务解决方案有很多种,主流的主要有:LCN、TCC、TXC三种模式,本文主要讲解LCN的原理。
想看TX-LCN官方文档请传送


[tx-lcn官方文档](https://www.codingapi.com/docs/txlcn-preface/)

一、分布式事务是什么?

分布式事务是基于服务微服务化之后引申出的事务问题;
在单体架构的服务中,通过本地事务一次性解决对数据库数据操作,通过本地事务实现数据的一致性,如下图左侧所示。
在微服务场景下就有可能出现A调用B服务的过程中,B服务成功了,A服务失败了,导致了最终AB数据不一致的情况,如下图右侧所示。
请添加图片描述
那么要解决分布式事务的问题,其实就是要考虑怎么实现数据的一致性,核心就是CAP定律 BASE理论,根据这个方向引申出了以下几种分布式事务解决方案:
1、TCC
TCC即Try、Confirm,Cancle,从翻译的字面意思理解其实就是这个解决方案的原理,对数据的提交和失败都做相应的业务补偿。
一般来说TCC都是指的一种解决方案,如果使用TX-LCN框架,更多指的是对Confirm的提交确认和Cancle的补偿机制,对补偿的业务代码逻辑性要求很高,这类方案其实还有很多需要升级的地方,后续有机会会补充讲解。

该模式对代码的嵌入性高,要求每个业务需要写三种步骤的操作。
该模式对有无本地事务控制都可以支持使用面广。
数据一致性控制几乎完全由开发者控制,对业务开发难度要求高。

2、LCN
LCN其实是对2PC模式的一种实现,即通过事务协调者来控制对业务事务的两段提交,和TXC其实算是一类模式,由TC和TM两个组件组成,TC负责客户端的事务代理和TM协作,TM负责管控事务的生命周期,以及记录异常日志。

该模式对代码的嵌入性为低。
该模式仅限于本地存在连接对象且可通过连接对象控制事务的模块。
该模式下的事务提交与回滚是由本地事务方控制,对于数据一致性上有较高的保障。
该模式缺陷在于代理的连接需要随事务发起方一共释放连接,增加了连接占用的时间。

3、TXC
TXC的实现原理是在执行SQL之前,先解析SQL,查询影响数据,然后保存执行的SQL快走信息和创建锁。当需要回滚的时候就采用这些记录数据回滚数据库,目前锁实现依赖redis分布式锁控制。

该模式与LCN模式类似同样对代码的嵌入性低。
该模式仅限于对支持SQL方式的模块支持。
该模式由于每次执行SQL之前需要先查询影响数据,因此相比LCN模式消耗资源与时间要多。
该模式不会占用数据库的连接资源。

二、TC和TM

来源Tx-LCN手册LCN模式的设计思路是由TM和TC组成的,其中图示的LCN代理连接池就是TC对客户端的代理,我们需要对业务工程的本地连接池代理,即需要对业务代码做控制,该控制的实现在Tx-LCN的设计方案里叫TC。

三、TC

3.1 TC的初始化

读一个框架,首先要看的是官方文档,通过文档我们可以了解到Tx-Lcn框架整体是对Spring进行了天生依赖,版本是SpringBoot2.x,在后续实现的解释中,我们就可以通过Springboot的官方文档参照研究TC模块的设计模式。
通过官方文档知道

TC模块在初始化过程中使用了很多@Configuration和@ConfigurationProperties的注解对配置进行管理。
例如:
1. 初始化Tx相关的信息
初始化Tx相关的信息
从这里其实可以通过解读该框架理解其他框架也是可以通过类似的方式,读取需要的用户配置。

2. 初始化对连接池和本地事务的代理:

在这里插入图片描述

3.2 TC对切点具体的实现方式

在这里插入图片描述

3.3 一切的开始源于Aspect包

1)代理初始化DataSource连接池;

2)通过对扫描注解@LcnTransaction对所有service服务,实现代理;

package com.codingapi.txlcn.tc.aspect;

import com.codingapi.txlcn.p6spy.CompoundJdbcEventListener;
import com.codingapi.txlcn.tc.config.TxConfig;
import com.codingapi.txlcn.tc.control.TransactionContext;
import com.codingapi.txlcn.tc.jdbc.JdbcTransactionDataSource;
import com.codingapi.txlcn.tc.resolver.AnnotationContext;
import org.springframework.aop.Advisor;
import org.springframework.aop.aspectj.AspectJExpressionPointcut;
import org.springframework.aop.support.DefaultPointcutAdvisor;
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

//初始化切点
@Configuration
public class AspectConfiguration {
   

//这里需要注意ConditionalOnMissingBean注解,该方法是用来构建唯一的事务切点上下文管理,为了保证事务的隔离性。
  @Bean
  @ConditionalOnMissingBean
  public TransactionAspectContext transactionAspectManager(TransactionContext transactionContext,
                                                           AnnotationContext annotationContext) {
   
    return new TransactionAspectContext(transactionContext, annotationContext);
  }

//1、该方法具体实现了对所有带有@LcnTransaction注解的方法切点,即对本地事务代理的初始化过程。
//2、对@LcnTransaction注解的扫描方式涉及到一个@annotation的切面增强的用法。
//3、依赖注入了txTransactionInterceptor来实现具体的拦截方法
  @Bean
  public Advisor txTransactionAdvisor(TxTransactionInterceptor txTransactionInterceptor, TxConfig txConfig){
   
    AspectJExpressionPointcut pointcut=new AspectJExpressionPointcut();
    pointcut.setExpression(txConfig.getTransactionPointcut());
    return new DefaultPointcutAdvisor(pointcut, txTransactionInterceptor);
  }

//1、同样需要注意的是@ConditionalOnMissingBean注解,该方法是用来构建唯一的事务切点上下文管理,为了保证事务的隔离性。
//2、数据源切点实现很简单,直接通过TxConfig默认注入的execution(* javax.sql.DataSource.getConnection(..))包来获取切点
//3、依赖注入了txDataSourceInterceptor来实现具体的拦截方法
  @Bean
  public Advisor txDataSourceAdvisor(TxDataSourceInterceptor txDataSourceInterceptor, TxConfig txConfig){
   
    AspectJExpressionPointcut pointcut=new AspectJExpressionPointcut();
    pointcut.setExpression(txConfig.getDatasourcePointcut());
    return new DefaultPointcutAdvisor(pointcut, txDataSourceInterceptor);
  }


//TxTransaction具体的拦截器
  @Bean
  public TxTransactionInterceptor txTransactionInterceptor(TransactionAspectContext transactionAspectContext){
   
    return new TxTransactionInterceptor(transactio
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值