`
dada_fangfang
  • 浏览: 146226 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

alipay分布式事务-初学笔记

阅读更多
今天看了下公司分布式事务的源码,对分布式事务由了初步的了解,先前没有接触过着方面的思想,所以不知道其他公司是不是也是类似的设计思想。

概念
原子活动:一个业务活动有N个数据操作,而这每一个操作都是一个原子活动
业务活动:就是一个本地事务。他包含多个原子活动,他们是一个事务,是一个整体

分布式事务必须建立在本地事务的基础之上,因为分布式事务必须要回查,而前提是本地事务的结果状态是成功还是回滚,本地事务成功,则所有的原子活动都成功,反之亦然。

源码分析
在本地事务中,我们先启动分布式事务,首先会读取当前线程活动中的记录(localThread),其实也就是看看你是不是多次启动了分布式事务,多次启动肯定是不行的。

接下来,是重点了

BusinessActivityManager这个也业务活动管理器,也是分布式事务的核心管理器,他提供了一系列方法(说白了就是一些列关于业务活动和原子活动的增删锁方法),这些活动记录都会存到xts服务器的数据库,不论业务成功还是回滚,结果都是要删除的。
这里的启动方法,会把业务活动记录的状态,标示为待提交,也就是说启动成功了。

接下来的也是重点,是事务的回查,也就是分布式事务真正执行的地方
首先我们要清楚,spring有几个同步器,说白了就是AOP,这里的回查用了TransactionSynchronizationAdapter这个同步适配器,他就2个方法,beforeCompletion和afterCompletion(int status),这两个方法是在本地事务的完成前和完成后调用的,前者嘛也就是准备下数据,数据时什么?就是原子活动,业务活动的数据

当本地事务完成的时候,就是调用afterCompletion(int status)参数的意思是本地事务的状态,成功还是回滚,如果本地回滚了,所有的原子活动当然也回滚,如果成功嘛,也都成功,

这些只是初学笔记,思路熟悉下而已,还有些我暂时也没看懂,以后搞懂了,再来跟新
分享到:
评论

相关推荐

    alipay-sdk-java目前最新的jar和source

    本文将详细解析“alipay-sdk-java”及其相关的“alipay-sdk-java-javadoc”和“alipay-sdk-java-source”。 首先,“alipay-sdk-java”是一个Java版本的SDK,它包含了支付宝接口调用所需的类库和方法。这些类库涵盖...

    包含alipay-sdk-java-1.0.0.jar,alipay-trade-sdk-1.0.0.jar

    这里提到的两个核心组件是`alipay-sdk-java-1.0.0.jar`和`alipay-trade-sdk-1.0.0.jar`。 `alipay-sdk-java-1.0.0.jar`是基础的支付宝Java SDK,它提供了与支付宝服务器通信的基本框架和类库。这个SDK包含了处理...

    alipay-sdk-java-all

    alipay-sdk-java-allalipay-sdk-java-allalipay-sdk-java-allalipay-sdk-java-allalipay-sdk-java-allalipay-sdk-java-allalipay-sdk-java-allalipay-sdk-java-allalipay-sdk-java-allalipay-sdk-java-allalipay-sdk...

    alipay-trade-sdk-20161215.zip

    《阿里alipay-trade-sdk-20161215.jar包详解》 在数字化经济时代,支付服务已经成为商业活动中的重要环节。阿里巴巴集团作为全球领先的电子商务巨头,为商家提供了强大的支付工具——Alipay(支付宝)。本文将深入...

    alipay-trade-sdk-1.0.0.jar和alipay-sdk-java20171201160035.jar

    在这个场景中,"alipay-trade-sdk-1.0.0.jar" 和 "alipay-sdk-java20171201160035.jar" 是两个重要的Java库,它们专门用于与支付宝接口进行交互。这两个文件在Maven中央仓库找不到,可能是因为它们是支付宝提供的...

    alipay-sdk-java20170307171631.jar

    本文将详细介绍2017年3月7日17时16分31秒发布的“alipay-sdk-java20170307171631.jar”——支付宝Java SDK的具体内容和使用方法。 一、SDK概述 "alipay-sdk-java20170307171631.jar"是支付宝专门为Java开发者提供的...

    alipay-sdk-python-3.3.398.rar

    本篇文章将详细介绍如何利用“alipay-sdk-python-3.3.398”这一版本的支付宝Python SDK,来实现高效、安全的在线支付集成。 首先,我们需要理解的是,"alipay-sdk-python-3.3.398.rar"是一个压缩包文件,其中包含了...

    alipay-trade-sdk-1.0.0.jar

    alipay-trade-sdk-1.0.0.jar alipay-trade-sdk-1.0.0.jar

    alipay-trade-sdk-20180225.jar

    支付宝面对面支付阿里封装包,2018年有修改,http://download.csdn.net/download/qq_36125733/10106693 提供的 alipay-trade-sdk-1.0.0.jar 已经不能正常使用

    alipay-sdk-java-3.4.49.ALL.jar

    alipay-sdk-java-3.4.49.ALL.jar

    alipay-sdk-java-3.3.0.jar

    alipay-sdk-java-3.3.0.jar

    alipay-sdk-java20170615110434.jar

    alipay-sdk-java20170615110434 支付宝支付开发的jar包,

    alipay-sdk-java

    alipay-sdk-java 对接alipay支付时较常使用的sdk包。

    alipay-sdk-java.zip

    本人最近开发相关,发现相关jar包下载非常慢,上传方便大家开发时下载 alipay-sdk-java-3.7.4.ALL alipay-sdk-java-3.7.110.ALL alipay-sdk-java-4.8.10.ALL alipay-sdk-java-4.9.28.ALL

    alipay-sdk-PHP-20150312220100

    本文将详细讲解"alipay-sdk-PHP-20150312220100"这一版本的支付宝SDK针对PHP开发者的具体应用及核心功能。 首先,"alipay-sdk-PHP-20150312220100"这个标题表明这是一个专为PHP语言设计的支付宝SDK,日期部分...

    alipay-sdk-java-all,Java SDK.zip

    alipay-sdk-java-all,Java SDK.zip

    aliPay-trade-sdk.zip

    阿里巴巴的`aliPay-trade-sdk`是一个专为开发者提供的支付服务接口SDK,主要用于集成支付宝的交易功能。这个SDK包含了处理各种在线支付场景所需的功能,如商品购买、退款、查询订单状态等。由于`maven`中央仓库没有...

    alipay-trade-sdk-20161215.jar

    这是近日官网下载的包,官网已经好久不更新了,那么这个应该是最新的了

    alipay-sdk-java-3.4.27.ALL.jar

    支付宝小程序推送jar包alipay-sdk-javaalipay-sdk-javaalipay-sdk-javaalipay-sdk-javaalipay-sdk-javaalipay-sdk-javaalipay-sdk-java

Global site tag (gtag.js) - Google Analytics