news 2026/4/18 2:00:38

告别if-else噩梦:流程编排技术

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
告别if-else噩梦:流程编排技术

作为一个优秀的程序员,要守住职业的底线。能简单快速的完成的一件事,就一定要用简单的方案快速完成。不可过度的设计,始终保持系统的简洁!

曾几何时,我对于流程编排这件事 嗤之以鼻,为什么呢?我认为流程编排是典型地过度设计。

在我看来,代码越直观越可靠,我不喜欢看代码的时候跳来跳去。但是流程编排后,要把各个方法放到扩展类,通过组合各个扩展类新建一个流程,实现业务功能,这能有什么好处呢?

业务中台要接入很多的业务方,每个业务方并不是完全相同。很多时候无法完全复用,需要改造系统适应新的业务。

新增业务代码时,务必要保证原有业务不受影响,如果没有流程编排能力,就会充斥大量的 if else 。

if (biz == BizA || biz == BizB) { //do some thing //这部分逻辑相同 if (biz == BizA) { //差异化处理 } if(biz == BizB) { //差异化逻辑 } }

例如上面的代码,不同的业务线若有差异化逻辑,需要新增分支单独处理。想象一下,当有 10 多个业务接入了你的系统,那么一定让人抓狂……

任何一个人都无法保证对 10 多种业务完全熟悉,每个人可能只负责 1 个业务,然而如果没有代码逻辑的隔离,维护者只能在千丝万缕中,才能找到目标代码逻辑。更可怕的是,每次新增一个业务,需要在原有的屎山中继续💩,不断新增 if else。直到有一天,有一个倒霉蛋改错了代码,导致其他重要业务受影响,引发线上故障。

想象一下,当你改了几行代码以后,要求测试同学,回归10 多个业务线的全部逻辑?这显然不现实。

以上的问题和痛点可归纳为:代码隔离性和业务扩展点问题。解决这两类问题有如下手段!

  • 使用流程引擎,为不同的业务配置不同的流程执行链

  • 使用插件扩展引擎,不同的业务实现差异化部分。

MemberClub 中大量使用流程引擎和插件扩展引擎解决业务隔离性和扩展性 问题。

MemberClub是托管在Gitee平台的开源项目,提供了付费会员的交易解决方案,在各类购买场景下提供各类会员形态的履约及售后结算能力,具体介绍可参见

https://gitee.com/juejinwuyang/memberclub

配置流程执行链

考虑到不同的会员产品交易提单流程不同,不同的产品应配置不同的流程,DemoMemberPurchaseExtension实现了购买扩展点,并且定义了三个流程执行链的配置方式。如截图所示~

定义流程节点

流程节点中的方法包括processsuccessrollbackcallback方法。

流程执行

流程执行时 需提供流程上下文对象。调用FlowChain.execute方法即可

实际执行阶段,各个流程节点被流程引擎串联起来依次执行,类似于责任链的设计模式,具体执行顺序如下图所示。

依次执行每个流程节点的process方法,若process方法出现异常,则执行rollback方法。若所有的process方法执行成功,则倒序依次执行success方法。

流程引擎执行原理

以下是FlowChain.execute方法执行原理。

public <T> void execute(FlowChain<T> chain, T context) { Exception exception = null; int index = -1; for (FlowNode<T> node : chain.getNodes()) { try { node.process(context); index++; } catch (Exception e) { if (e instanceof SkipException) { CommonLog.warn("当前流程:{} 发出 Skip请求,后续流程不再执行", node.getClass().getSimpleName()); break; } exception = e; break; } } if (exception != null) { for (int i = index; i >= 0; i--) { FlowNode<T> node = chain.getNodes().get(i); try { node.rollback(context, exception); } catch (Exception e) { CommonLog.error("rollback执行异常,忽略 name:{}", node.getClass().getSimpleName(), e); } } } else { for (int i = index; i >= 0; i--) { FlowNode<T> node = chain.getNodes().get(i); try { node.success(context); } catch (Exception e) { CommonLog.error("success 执行异常,忽略 name:{}", node.getClass().getSimpleName(), e); } } } for (int i = index; i >= 0; i--) { FlowNode<T> node = chain.getNodes().get(i); try { node.callback(context, exception); } catch (Exception e) { CommonLog.error("callback执行异常,忽略 name:{}", node.getClass().getSimpleName(), e); } } if (exception != null) { throw exception; } }

以上全部代码地址,可以参见 MemberClub:

https://gitee.com/-/ide/project/juejinwuyang/memberclub/edit/master/-/memberclub.common/src/main/java/com/memberclub/common/flow/FlowChainService.java

MemberClub是托管在Gitee平台的开源项目,提供了付费会员的交易解决方案,在各类购买场景下提供各类会员形态的履约及售后结算能力,一个非常好的项目,适合用来学习业务中台系统,具体介绍可参见

Gitee开源地址:

https://gitee.com/juejinwuyang/memberclub

GitHub开源地址:

https://github.com/juejin-wuyang/memberclub

在这个项目中你可以学习到 SpringBoot 集成 以下框架或组件。

  • Mybatis-plus

  • Sharding-sphere 多数据源分库分表

  • Redis/redisson

  • Apollo

  • Springcloud(feign/enreka)

  • RabbitMQ

  • H2 内存数据库

  • Swagger

  • Lombok+MapStruct

同时你也可以学习到以下组件的实现原理

  • 流程引擎

  • 扩展点引擎

  • 分布式重试组件

  • 通用日志组件

  • 商品库存

  • 分布式锁组件

  • Redis Lua的使用

  • Spring 上下文工具类

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/15 13:34:10

吐血推荐专科生必用TOP9AI论文网站

吐血推荐专科生必用TOP9AI论文网站 2026年专科生论文写作工具测评&#xff1a;为何需要一份精准榜单&#xff1f; 随着AI技术在教育领域的深入应用&#xff0c;越来越多的专科生开始借助AI工具提升论文写作效率。然而&#xff0c;面对市场上五花八门的论文辅助平台&#xff0c;…

作者头像 李华
网站建设 2026/4/17 18:03:57

提升效率:如何为企业挑选完美的RFID解决方案

在物联网赋能企业数字化转型的进程中&#xff0c;RFID&#xff08;射频识别&#xff09;技术凭借非接触式批量读取、数据实时上传、标签抗磨损等核心优势&#xff0c;已成为物流仓储、智能制造、零售管控等领域提升效率的关键抓手。然而&#xff0c;多数企业在选型时易陷入“参…

作者头像 李华
网站建设 2026/4/15 22:07:41

智能座舱:汽车内饰的交互革命

一、引言&#xff1a;从交通工具到第三空间的本质变革 汽车产业的百年演进中&#xff0c;座舱始终是连接人与车的核心载体。从最初仅满足驾乘功能的机械空间&#xff0c;到如今集成人工智能、物联网、显示技术的智能终端&#xff0c;座舱的进化史本质上是一部人机交互的革命史。…

作者头像 李华
网站建设 2026/3/20 22:49:43

柔性生产:小批量定制与大规模生产的完美融合

一、生产模式的时代演进&#xff1a;从规模标准化到柔性协同化 工业革命以来&#xff0c;生产模式的变革始终围绕着“效率”与“需求”的平衡不断迭代。上世纪初&#xff0c;福特汽车开创的流水线大规模生产模式&#xff0c;以标准化产品、专业化分工和连续性作业为核心&#x…

作者头像 李华
网站建设 2026/4/17 23:09:03

厂房车间设备摆放平面图在线绘制的规范要求和模板大全

在工业生产领域&#xff0c;厂房车间设备摆放平面图是连接生产规划与实际落地的关键技术文档。它不仅直观呈现了车间内设备、通道、仓储区域、安全设施等核心要素的空间布局&#xff0c;更直接影响生产流程的顺畅性、空间利用效率、操作人员安全以及后续产能扩展的可行性。无论…

作者头像 李华
网站建设 2026/4/16 12:34:32

增量微调优化在线更新

&#x1f493; 博客主页&#xff1a;借口的CSDN主页 ⏩ 文章专栏&#xff1a;《热点资讯》 智能优化&#xff1a;增量微调在线更新的效率革命与伦理挑战 目录 智能优化&#xff1a;增量微调在线更新的效率革命与伦理挑战 引言&#xff1a;动态AI的进化需求 现在时&#xff1a;成…

作者头像 李华