最近研究了一下分布式事务框架,ttc,总体感觉还可以,当然前提条件下是你要会使用这个框架。下面分层次讲,尽量让想学习的同学读了这篇文章能加以操作运用。我不想废话,直接上干货。

一.什么是tcc?干什么用的?

      ttc是分布式事务框架,用于分布式事务的。分布式事务就是针对两个以上的库操作数据事务管理的,比如操作A库B库,当B库失败,也要把A库哪一步操作也要回滚。

ttc其实是一个模板框架,是英文字母try,confirm,cnacel三个单词的缩写。我们要操作的业务处理部分在try里面执行,执行的所有结果是否有失败的情况在confirm里面确认,如果有失败,则在cancel里面做回滚操作。不要问我什么是回滚操作,回滚操作就是比如你增加了一条数据,回滚就指你去删掉这条数据。相信已经够直白了。

二.模板什么样子?怎么使用?

      首先我贴出模板框架,大概TccTemplate,TccResult,TccCallBack,TranslationTask 四个类

public class TccTemplate {

    private static final Logger logger = LoggerFactory.getLogger(TccCallBack.class);

    /**
* 分布式事务模板
*
* @param tccCallBack 分布式事务执行回调
* @param method 当前方法名(封装参数, 可方便捞取数据)
*/
public static TccResult process(TccCallBack tccCallBack, String method) {
// 返回一个消息用于
TccResult tccResult = new TccResult();
String msg = "";
try {
// 执行主业务
tccCallBack.tryExecute();
// 进行确认执行结果,如果结果是false,则执行回滚操作
boolean confirm = tccCallBack.confirm();
if (confirm) {
tccResult.setStatus(true);
msg = String.format("分布式事务{%s}执行成功", method);
logger.info(msg);
} else {
tccResult.setStatus(false);
msg = String.format("分布式事务{%s}执行失败,进行回滚操作", method);
logger.warn(msg);
tccCallBack.cancel();
}
} catch (BizException e) {
// 主流程发生异常, 则直接执行回滚操作
tccResult.setStatus(false);
tccResult.setCode(e.getErrorCode().getCode());
msg = e.getMessage();
logger.warn(String.format("分布式事务{%s}执行发生异常,进行回滚操作", method), e);
tccCallBack.cancel();
throw e;
}catch (BusinessException e) {
// 主流程发生异常, 则直接执行回滚操作
tccResult.setStatus(false);
tccResult.setCode(e.getErrorCode());
msg = e.getErrorMessage();
logger.warn(String.format("分布式事务{%s}执行发生异常,进行回滚操作", method), e);
tccCallBack.cancel();
throw e;
} catch (Exception e) {
// 主流程发生异常, 则直接执行回滚操作
tccResult.setCode(BizErrorCodeEnum.UNSPECIFIED.getCode());
tccResult.setStatus(false);
msg = e.getMessage();
logger.warn(String.format("分布式事务{%s}执行发生异常,进行回滚操作", method), e);
tccCallBack.cancel();
throw e;
} finally {
// 返回结果Result
tccResult.setMsg(msg);
return tccResult;
}
}
} 框架种用到的类也给大家贴出来:
public class TccResult<T> {

    private String code;
/** 响应数据 */
private T data;
/** 响应状态 */
private Boolean status = true;
/** 响应消息 */
private String msg; public T getData() {
return data;
} public void setData(T data) {
this.data = data;
} public Boolean getStatus() {
return status;
} public void setStatus(Boolean status) {
this.status = status;
} public String getMsg() {
return msg;
} public void setMsg(String msg) {
this.msg = msg;
} public String getCode() {
return code;
} public void setCode(String code) {
this.code = code;
}
}
public interface TccCallBack {
/**
* 执行主要分布式业务操作
*/
void tryExecute(); /**
* 确认分布式业务操作最终结果,
* 如果返回true,则不执行cancel,返回false则执行cancel
*/
boolean confirm(); /**
* 取消操作
*/
void cancel();
}
@Data
@NoArgsConstructor
@AllArgsConstructor
public class TranslationTask { private String name; private Object parameter;
}

新学习这个框架的同学,可以先在项目里面建立一个文件夹,然后把这四个类copy进去,然后在你需要用到的地方,直接用就行,具体使用,举例子,我也直接来干货。

比如我想在test方法里面用到分布式事务,用伪代码表示具体逻辑,下单在订单库,用户在用户库
public Boolean test(Map<String, String> inParams) {
//把操作成功的结果放进这里
Stack<Object> taskStack = new Stack<>();
//暂存分布式结果
HashMap<String,Boolean > tempResult = Maps.newHashMap();
   // 分布式事务调用
TccResult process = TccTemplate.process(new TccCallBack() {
@Override
public void tryExecute() { boolean flag=false; 1.下单,生成订单id
         if(订单id不为空){
           taskStack.push(new TranslationTask("1",订单id));
           flag=true;
               }else{
flag=false;
}
               

               2.下单成功后,改用户状态
         if(flag){
         修改用户状态
}
               if(修改用户状态成功){
           flag=true;
         }else{
flag=false;
}
              tempResult.put("result", flag);
}

      @Override
public boolean confirm() {
return tempResult.get("result") == true ;
} @Override
public void cancel() {
for (int i = 0; i < taskStack.size(); i++) {
TranslationTask translationTask = (TranslationTask) taskStack.pop();
switch (translationTask.getName()) {
case "1":
订单id = translationTask.getParameter();
根据订单id删除生成的订单
break;
default:
break;
}
} }
}, "分布式事务测试");
return tempResult.get("result");
} 上面伪代码其实就是指先下单,下单成功的话,把结果装到taskStack里面,装到这里是为了用于取出数据回滚用。然后还有个tempResult,这个类的作用目的在于把每一步的结果放进去,用于确认的,如果有一步失败,将会回滚操作
如果有疑问,请留言,或者喜欢请给个关注,我会持续为大家用尽量通俗的话,不讲废话,把好的东西分享出来。

java基础之----分布式事务tcc的更多相关文章

  1. Hmily:高性能异步分布式事务TCC框架

    Hmily框架特性 无缝集成Spring,Spring boot start. 无缝集成Dubbo,SpringCloud,Motan等rpc框架. 多种事务日志的存储方式(redis,mongdb, ...

  2. [跨数据库、微服务] FreeSql 分布式事务 TCC/Saga 编排重要性

    前言 FreeSql 支持 MySql/SqlServer/PostgreSQL/Oracle/Sqlite/Firebird/达梦/Gbase/神通/人大金仓/翰高/Clickhouse/MsAcc ...

  3. 微服务痛点-基于Dubbo + Seata的分布式事务(TCC模式)

    前言 Seata 是一款开源的分布式事务解决方案,致力于提供高性能和简单易用的分布式事务服务.Seata 将为用户提供了 AT.TCC.SAGA 和 XA 事务模式,为用户打造一站式的分布式解决方案. ...

  4. Java后端工程师必备书单(从Java基础到分布式)

    Java开发工程师一般负责后端开发,当然也有专门做Java Web的工程师,但是随着前后端的分离,越来越多的Java工程师需要往大后端方向发展. 今天我们就来介绍一下Java后端开发者的书单. 首先要 ...

  5. .Net Core with 微服务 - 分布式事务 - TCC

    上一次我们讲解了分布式事务的 2PC.3PC .那么这次我们来理一下 TCC 事务.本次还是讲解 TCC 的原理跟 .NET 其实没有关系. TCC Try 准备阶段,尝试执行业务 Confirm 完 ...

  6. Java之分布式事务TCC

    看这个博客吧! 挺好的. 理论:https://www.cnblogs.com/jajian/p/10014145.html 实践:https://www.cnblogs.com/sessionbes ...

  7. 高性能异步分布式事务TCC框架(资料汇总)

    https://github.com/yu199195/hmily tcc源码解析系列(一)之项目结构 https://yu199195.github.io/2017/10/11/TCC/tcc-on ...

  8. SpringCloud分布式事务TCC实现

    可以参考 http://www.txlcn.org/ 的实现方式

  9. 分布式事务二TCC

    分布式事务解决方案之TCC 4.1.什么是TCC事务 TCC是Try.Confirm.Cancel三个词语的缩写,TCC要求每个分支事务实现三个操作:预处理Try.确认Confirm.撤销Cancel ...

随机推荐

  1. JVM -XX: 参数列表

    功能开关: 参数 默认值或限制 说明 参数 默认值 功能 -XX:-AllowUserSignalHandlers 限于Linux和Solaris,默认不启用 允许为java进程安装信号处理器,信号处 ...

  2. Lecture Collection

    Distributed ML Yibo Zhu 主要讲了如何分布式的进行机器学习,主要用到的思想是指令的流水调度的相关的思想. IoT Zhenjiang Li 普通的各种卡是基于PIN来进行身份验证 ...

  3. "?:"在正则表达式中什么意思

    “?:”非获取匹配,匹配冒号后的内容但不获取匹配结果,不进行存储供以后使用. 单独的“?”:匹配前面的子表达式零次或一次. 当“?”紧跟在任何一个其他限制符(*,+,?,{n},{n,},{n,m}) ...

  4. H3C CSMA/CD载波侦听

  5. H3C 物理层

  6. Python--day72--json内容回顾

    前后端分离,Json格式字符串:序列化和反序列化 """ 复习python中的json模块 """ import json s = '{&q ...

  7. 【u128】又一个数字游戏

    Time Limit: 1 second Memory Limit: 128 MB [问题描述] 小明拿出了一个素数集合,{2, 3, 5, 7, 11, 13, -, 127, -},他发现,从小到 ...

  8. LeekCode解题记录

    昨天晚上有个LeekCode的比赛,两个半小时解五题,轻松解决前两题后,卡在第三题,还剩半小时时放弃,开始解第五题,解完但未验证通过,第四题只看了下题目. 排名第一的大佬只用了36分钟全部写完. 差距 ...

  9. 面试题 —— Ajax的基本原理总结

    Ajax 的全称是Asynchronous JavaScript and XML(异步的JavaScript 和 XML),其中,Asynchronous 是 异步 的意思,它有别于传统web开发中采 ...

  10. hdu 6851 Vacation(思维+贪心)

    传送门 •题意 有编号0到n,n+1辆车排队过红绿灯,从0到n离交通灯线越来越近 每辆车都有一个最大速度v,车身长度l,和离交通灯线的距离s, 一辆车头到达线则说明这辆车已到达线 如果一辆车前面没有紧 ...