分布式事务实战——seata整合flowable(一)

seata整合flowable——AT模式实战

章节简介:

  1. 背景介绍
  2. 实战部分
  3. 踩坑和解决方案

1.背景介绍

背景是微服务项目,采用的是seata分布式事务整合flowable工作流引擎。
首先看业务场景,需要做分布式事务改造的分为工作流服务、业务服务两个微服务,其中:

a.工作流服务就是flowable引擎封装的发起流程、审批等部分。
通过工作流引擎提供的ExecutionListener事件监听器在审批结束之后调用业务的审批通过接口。
b.业务服务主要是通过调用flowable服务的送审、接收flowable的审批回调完成自身对业务单据状态的修改。
在这里插入图片描述

2.实战——全局事务的发起和验证

整合seata和flowable,关键点在于弄清楚全局事务的发起方,也就是@GlobalTransactional的添加位置。
以下简称工作流服务为workflow,业务服务简称为business。

a).发起流程

发起流程,也就是business传递业务单据的businessKey(业务唯一键),去调用workflow服务的对应发起流程接口,然后workflow成功之后business接收返回。
全局事务添加在business业务服务的发起流程方法上即可,如果需要验证seata的全局事务,参照下图:
在这里插入图片描述
如何验证:
可以在workflow发起流程成功但是没有返回之前打断点,正常的情况应当是:

business的sql都已经提交了,可以在数据库查证,但是seata的undo_log表中business本次提交的反向sql没有被删除。

当你在断点位置构造一个异常,可以发现seata的日志会提示:undo_log表的反向sql被执行,全局事务回滚,回滚完成后undo_log表的对应sql记录被删除,分布式验证也就成功了。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
本课程是《Flowable流程入门课程》的后续高级课程。在学习本课程前,应先学习入门课程,以掌握相关基础知识。高级课程着重讲解Flowable工作流的高级概念、复杂理论和实战应用。课程内容包括流程管理思想、技术与标准、工作流的控制模式和资源模式;Flowable数据库表及变量;与Spring、Spring Boot的集成;BPMN 2.0主要类图;Flowable高级服务如JAVA服务任务、脚本任务、Web Service任务、外部工作者任务、多实例任务、补偿处理程序、子流程和调用活动等;Flowable事件侦听器、执行侦听器和任务侦听器;Flowable历史和REST API;Flowable事务、并发性、身份管理及LDAP集成;Flowable高级主题如流程实例迁移、异步执行器的设计与配置、用于高并发的UUID ID生成器、多租户、高级流程引擎配置、执行自定义SQL和实验性流程调试器等;Flowable Eclipse设计器特性及定制;Flowable 事件注册;Flowable相关标准和规范如ISO8601标准和cron等。本课程对Flowable官方文档进行了彻底梳理和融汇贯通,并结合实践,形象生动、系统全面、简单易懂地呈现给大家,让大家从开源软件文档冗长耗时、英文晦涩难懂、概念理解困难、知识点分散等困境中解脱出来,从而能快速地将Flowable具有的高级特性应用到项目的高级需求和复杂实践中去。课程特色:案例和代码驱动、基础概念与经典实战相结合、知识环节融会贯通、关联知识平滑拓展、概念和原理展示形象生动。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值