分布式事务是面试经常被问到的一个问题,今天我们分析一下TCC事务 首先我们看一个场景,如下图 有个订单服务生成订单的时候,会调用库存服务,积分服务,仓储服务的接口,库存服务会进行扣减库存,积分服务进行增加积分...T(try):一般就是锁定某个资源,设定一个预备类的状态,冻结部分数据,如下图 C(commit),当try阶段都执行成功,这里就是真正进行提交完成,如下图 C(cancel),当try阶段库存失败...,这里就进行回滚的操作,如下图 以上就是TCC事务的基本操作, 事务中的每一个接口由原来的一个接口,变成了三个接口,分别是try接口,comfirm接口,cancel接口 先是调用所有服务的try...接口 如果try都正常,TCC事务就进行Confirm接口 如果try某个的服务有异常,TCC事务就会进行回滚操作,调用cancel接口 其中我们可以发现,如果订单服务挂了,然后重启,那么之前没有执行完的事务如何处理...其实这里TCC框架会记录分布式事务的活动日志,可在磁盘的日志文件中记录,也可以记录到数据库,保存各个事务的运行阶段和状态 还有就是当cancel和comfirm执行失败,TCC框架也会根据日志记录和状态进行不断尝试
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/128570.html原文链接:https://javaforall.cn
在分布式事务 TCC 中 T 阶段要先锁住金额以便事务失败回滚时不会出现金额被取走导致回滚失败出现负账。...预留金额模式 入账 T:账户+入账,预留+入账 C:预留-入账 R:账户-入账,预留-入账 出账 T:预留+出账 where 账户-预留>出账 C:账户-出账,预留-出账 R:预留-出账 可用余额模式...入账 T:账户+入账 C:可用+入账 R:账户-入账 出账 T:可用-出账 where 可用>出账 C:账户-出账 R:可用+出账 可以看出可用余额模式要简单得多。
TCC(事务补偿) TCC(Try Confirm Cancel)方案是一种应用层面侵入业务的两阶段提交。 其核心思想是:针对每个操作,都要注册一个与其对应的确认和补偿(撤销)操作。...在 TCC 事务机制中认为,如果在 Try 阶段能正常的预留资源,那 Confirm 一定能完整正确的提交。...也就是说只要Try成功,Confirm一定成功(TCC设计之初的定义) 。...3、Confirm与Cancel如果失败,由TCC框架进行==重试==补偿 4、存在极低概率在CC环节彻底失败,则需要定时任务或人工介入 方案总结 TCC 事务机制相比于 XA 事务机制...缺点: 1、TCC 的 Try、Confirm 和 Cancel 操作功能要按具体业务来实现,业务耦合度较高,提高了开发成本。 1、Try-Confirm 2、Try-Canal
本文主要基于 TCC-Transaction 1.2.3.3 正式版 1. 概述 2. TCC 原理 3. TCC-Transaction 原理 4....概述 本文分享 TCC 实现。主要涉及如下三个 Maven 项目: tcc-transaction-core :tcc-transaction 底层实现。...tcc-transaction-api :tcc-transaction 使用 API。 tcc-transaction-spring :tcc-transaction Spring 支持。...TCC-Transaction 原理 在 TCC 里,一个业务活动可以有多个事务,每个业务操作归属于不同的事务,即一个事务可以包含多个业务操作。...方法,发起 TCC 整体流程。
这里简单提一句,如果你要玩儿 TCC 分布式事务,必须引入一款 TCC 分布式事务框架,比如国内开源的 ByteTCC、Himly、TCC-transaction。...如果你在各个服务里引入了一个 TCC 分布式事务的框架,订单服务里内嵌的那个 TCC 分布式事务框架可以感知到,各个服务的 Try 操作都成功了。...此时,TCC 分布式事务框架会控制进入 TCC 下一个阶段,第一个 C 阶段,也就是 Confirm 阶段。 为了实现这个阶段,你需要在各个服务里再加入一些代码。...那订单服务内的 TCC 事务框架是可以感知到的,然后它会决定对整个 TCC 分布式事务进行回滚。 也就是说,会执行各个服务的第二个 C 阶段,Cancel 阶段。...总结一下,你要玩儿 TCC 分布式事务的话:首先需要选择某种 TCC 分布式事务框架,各个服务里就会有这个 TCC 分布式事务框架在运行。
TCC于BASE相比,增加了业务检查和撤销事务的功能。...同时,TCC将2PC数据库层面的动作提升到了服务层面,不同的是TCC的所有动作都是一个本地事务,每个本地事务都在动作完成后commit到数据库: Try相当于2PC的Commit request phase...不过TCC在处理这种情况相比2PC具有一些优势,因为TCC是在服务层面的,当出现这种问题的时候可以很容易通过日志、业务数据排查出来,然后人工介入,而2PC完全是数据库底层的。...对于ACID的保证 TCC对于ACID的保证: A,正常情况下保证 C,在某个时间点,会出现A库和B库的数据违反一致性要求的情况,但是最终是一致的 I,在某个时间点,A事务能够读到B事务部分提交的结果...D,和本地事务一样,只要commit则数据被持久 实现TCC时的注意事项 实现TCC需要关注以下几个方面: TCC模式在于服务层面而非数据库层面 TCC模式依赖于各服务正确实现Try、Confirm、Cancel
比如补偿模式下的Tcc模式的流程: 一、整个流程 整个流程下来,Tcc的执行流程比较简单,相对于AT模式而言。首先初始化事务协调器TC。完成事务协调器之后,启动服务端Netty。...二、使用Seata的Tcc模式 引入seata client的依赖 业务逻辑上加@GlobalTransactional作为发起方的标识 引入@TwoPhaseBusinessAction,带注解的方法是...处理tcc切面,和返回业务结果。 4)ActionInterceptorHandler处理tcc切面,和返回业务结果。进行日志存储doTccActionLogStore。
目标 通过本案例的学习,掌握Hmily实现TCC事务控制的方法,掌握TCC事务控制的思想。 Hmily介绍 Hmily是一个高性能分布式事务TCC开源框架。...基于Java语言来开发(JDK1.8),支持Dubbo,Spring Cloud等RPC框架进行分布式事务。...幂等: 通过前面介绍已经了解到,为了保证TCC二阶段提交重试机制不会引发数据不一致,要求 TCC 的二阶段 Try、Confirm 和 Cancel 接口保证幂等,这样不会重复使用或者释放资源。.../dtx-tcc-demo-bank1 银行1,操作张三账户, 连接数据库bank1 dtx/dtx-tcc-demo/dtx-tcc-demo-bank2 银行2,操作李四账户,连接数据库bank2...两个测试工程如下: dtx/dtx-tcc-demo/dtx-tcc-demo-bank1 银行1,操作张三账户,连接数据库bank1 dtx/dtx-tcc-demo/dtx-tcc-demo-bank2
在该论文中,TCC还是以Tentative-Confirmation-Cancellation命名。正式以Try-Confirm-Cancel作为名称的是Atomikos公司,其注册了TCC商标。...概述TCC是Try-Confirm-Cancel的简称。 TCC模式与AT模式非常相似,每阶段都是独立事务,不同的是TCC通过人工编码来实现数据恢复。需要实现三个方法: Try:资源的检测和预留。...通常情况下,采 用TCC则认为Cancel阶段也是一定成功的。若Cancel阶段真的出错了,需引入重试机制或人工处理。...与AT模式与TCC模式的对比 AT模式TCC模式一阶段 prepare在本地事务中,一并提交业务数据更新和相应回滚日志记录调用 自定义的 prepare 逻辑二阶段 commit马上成功结束,自动异步批量清理回滚日志调用...幂等为了保证TCC二阶段提交重试机制不会引发数据不一致,要求 TCC 的二阶段 Try、 Confirm 和 Cancel 接口保证幂等,这样不会重复使用或者释放资源。
所以为了有效的使用内存,就把内存划分成一个个小的内存单元,每个内存单元的大小是一个字节。
由于工作需要用到C语言,所以开始接触学习C语言,从最基础开始学习了解。...C语言中的关键字: auto 声明自动变量 break 跳出当前循环 case 开关语句分支 char 声明字符型变量或函数返回值类型 const 声明只读变量 continue...C变量 基本数据类型 char int float double void C常量 常量是固定值,在程序执行期间不会改变 字符常量 \n 换行符 \f 换页符 \r...回车 C存储类 auto register static extern C运算符 算术运算符 + - * / % ++ – 关系运算符 == !...: 条件表达式 枚举 enum C中操作字符串的函数 strcpy(s1,s2) 复制字符串s2到字符串s1 Strcat(s1,s2) 连接字符串s2到字符串s1的末尾 Strlen(
一、C 语言发展 C 语言 被开发之前 并 没有经过 缜密 的 设计 , 而是在 使用过程中 逐渐完善的 ; C 语言发展经过如下阶段 : 初始阶段 : 1972年至1978年 , C语言 初步形成 ,...C99 , C11 , C17 等标准 , 以满足新的编程需求 ; 二、C 语言缺陷 C 语言有如下缺陷 : C 语言 没有经历过 缜密的 设计过程 , 都是根据需求逐渐完善的 , 出现了很多缺陷和漏洞...2、C 语言与 C++ 语言关系 C 语言 与 C++ 语言 并 不是 竞争关系 ; C++ 语言 是 以 C 语言为基础 的 加强版本编程语言 , 可以看作是更好的 C 语言 , 在 C++ 语言...中 , 可以使用 C 语言语法 , 对 C 语言完全兼容 ; C++ 语言 包含 C 语言 , 在 C++ 代码中可以使用 C 语言的语法 , 但是在 C 语言中不能使用 C++ 的语法 ; 3、C++...语言应用场景 C 语言 和 C++ 语言的应用场景 : C语言 应用场景 : 系统软件、操作系统、编译器等 底层系统级应用 ; C++ 语言 应用场景 : 大型应用程序、游戏 等更 高级的应用 ; 在不同的
一、主函数 C语言的主函数是main()函数,有且仅有一个。 例如: int main() { return 0; } 是一个标准的C语言主函数。...二、输入、输出函数 C语言中的输出函数为printf,输入函数为scanf,使用前需要引用头文件#include 。...(2)C语言中的常见单位(从小到大): bit(比特)<byte(字节)<KB<MB<GB<TB<PB<..... 1byte = 8bit 1KB = 1024byte 1MB = 1024KB...四、变量和常量 4.1 变量的使用 C语言中常量是不变的值,变量是可变的值 创建变量的使用: int age = 10; char ch = 'w'; float weight = 45.5f...4.3 常量 C语言中的常量分为字面常量,const修饰的常变量,#define 定义的标识符常量,枚举常量。 (1)字面常量:100,'w',3.14等。
C语言的重要性 C语言是所有高级语言的前辈,C++,C#,Java ,都是由C语言演变过来的,包括现在很火的python,第一个Python编译器诞生,它是用C语言实现的。...所有大学理科专业的必修课程都是C语言,就算你将来不从事开发, 期末考试总不能挂科吧,除了C语言,小林不知道还有哪一门课这么普及。...我们常用的操作系统windows、linux、unix是C语言开发的,如果你想当黑客必须学C语言,你去黑别人电脑的是不是绕不操作系统。 如果你想入职阿里、腾讯这样的大厂,必须学C语言,为什么呢?...C语言应用领域 操作系统:windows、linux、unix 数据库:Oracle和sql server 一些驱动程序 wps、photoshop 嵌入式开发 C语言特点 C语言简洁,灵活,有37个关键字...C语言数据类型极其丰富。 C语言程序执行效率很高,可以直接操作内存。 C语言学习目标 掌握C语言的语法规则,数组、循环、函数、指针等。 要学会一些算法,比如冒泡排序、快速排序、递归等。
C语言作为一种高效、灵活且具有底层控制能力的编程语言,在软件开发的多个领域中得到了广泛应用。以下是C语言在主要应用领域中的总结: 1....操作系统开发 1.1 操作系统内核 C语言因其高效性和底层硬件控制能力,被广泛用于编写操作系统内核。Unix、Linux和Windows等操作系统的内核部分主要是用C语言编写的。...3.2 游戏开发 C语言因其高性能和低级控制能力,在游戏开发中扮演重要角色。许多游戏引擎和图形渲染库,如SDL、OpenGL的底层实现,都是用C语言编写的。...网络编程 4.1 网络协议实现 许多网络协议的实现,如TCP/IP协议栈,都是用C语言编写的。C语言的高效性和低级操作能力使其成为网络协议实现的理想选择。...9.3 系统编程 C语言在系统编程课程中扮演重要角色,学生通过学习C语言可以理解操作系统、文件系统、网络编程和并发编程的基本原理和实现方法。 10.
ages)/sizeof(int); //数组的总长度除以单个的长度等于元素个数 三、数组内存存储细节 假设有数组如下: Int x[]={1,2}; Char ca[5]={‘a’,‘A’,‘B’,‘C’...使用场合:五子棋,俄罗斯方块等, 假设: char Y[3][2]={ {‘A’,‘B’}, {‘C,‘D’}, {‘E,‘F’} }; 内存情况: ?
//总之:这个拷贝是分三块区域的,最前面的一块区域满足dest<src //我们只能从前往后进行拷贝,不然会出错误 //而剩下的两块区域可以同时从后往前进行拷贝,那么我们就将这两块区域放在一起 在C语言标准中
C语言的开发场景: 应用软件 主要包含各种软件如:QQ,百度网盘,游戏 (上层) 操作系统 windows/macOS/Linux (下 电脑硬件 ...层) C语言是一个擅长底层开发的语言。...而C语言的主要编译器有:Clang/GCC/MSVS。
一.C语言是什么?...语言大致可以分为自然语言和计算机语言,自然语言就是人与人日常交流的语言,如汉语、英语、日语等等,计算机语言又可以分为机器语言、汇编语言、高级语言,C语言就是一个高级语言 机器语言:就是由二进制01组合起来的计算机可以直接识别的程序语言是一种面向机器的语言...,比起低级语言易懂易学,可移植性好,编程效率高,但是执行效率没有低级语言高,需要经过编译或解释,C语言就是采用编译的一种高级语言 二.为什么选择C语言 C语言常年霸榜各类高级语言前三,属于基础必学的语言...,其功能强大,而且许多语言都很相似,如果学好C语言,对学习其他语言也有很大帮助 三.编译器的选择 C语言是一门编译型的语言,需要依赖编译器将计算机语言转换成机器能够执行的机器指令 常见的编译器有:msvc...+文件,这里没有C文件选项,因为C++和C基本不分家,将后缀名.cpp改为.c就可以了,创建好后就可以开始写我们的第一个C语言程序了 注意:其中.c的文件叫源文件,.h的文件叫头文件(head),后面会慢慢讲到