news 2026/5/30 16:31:07

通用流程编排框架,Solon Flow v3.8.0 隆重发布

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
通用流程编排框架,Solon Flow v3.8.0 隆重发布

面向全场景的 Java 通用流程编排框架。同时兼容 java8 ~ java25,是 OpenSolon 的重要组成部分。支持已知流程编排的各种场景:

  • 可用于计算(或任务)的编排场景
  • 可用于业务规则和决策处理型的编排场景
  • 可用于可中断、可恢复流程(结合自动前进,停止,再执行)的编排场景

可视化设计器:

  • https://solon.noear.org/flow/designer/
  • 第三方开源(已组件化):https://gitee.com/opensolon/solon-flow-bpmn-designer

嵌入第三方框架(SpringBoot、jFinal、Vert.X、Quarkus、Micronaut 等)的示例:

  • https://gitee.com/solonlab/solon-flow-embedded-examples
  • https://gitcode.com/solonlab/solon-flow-embedded-examples
  • https://github.com/solonlab/solon-flow-embedded-examples

一、最近更新了什么?

重要变化:

  • 第六次预览
  • 取消“有状态”、“无状态”概念。
  • solon-flow 回归通用流程引擎(分离“有状态”的概念)。
  • 新增 solon-flow-workflow 为工作流性质的封装(未来可能会有 dataflow 等)。

具体更新:

  • 插件solon-flow第六次预览
  • 新增solon-flow-workflow插件(替代 FlowStatefulService)
  • 添加solon-flowFlowContext:lastNode() 方法(最后一个运行的节点)
  • 添加solon-flowFlowContext:lastNodeId() 方法(最后一个运行的节点Id)
  • 添加solon-flowNode.getMetaAs, Link.getMetaAs 方法
  • 添加solon-flowNodeSpec:linkRemove 方法(增强修改能力)
  • 添加solon-flowGraph:create(id,title,consumer) 方法
  • 添加solon-flowGraph:copy(graph,consumer) 方法(方便复制后修改)
  • 添加solon-flowGraphSpec:getNode(id) 方法
  • 添加solon-flowGraphSpec:addLoop(id) 方法替代 addLooping(后者标为弃用)
  • 添加solon-flowFlowEngine:eval(Graph, …) 系列方法
  • 优化solon-flowFlowEngine:eval(Node startNode) 处理,改为从 root 开始恢复到 start 再开始执行(恢复过程中,不会执行任务)
  • 调整solon-flow移除 Activity 节点预览属性 “i m o d e " 和 " imode" 和 "imode""omode”
  • 调整solon-flowActivity 节点流出改为自由模式(可以多线流出:无条件直接流出,有条件检测后流出)
  • 调整solon-flowNode.getMeta 方法返回改为 Object 类型(并新增 getMetaAs)
  • 调整solon-flowEvaluation:runTest 改为 runCondition
  • 调整solon-flowFlowContext:incrAdd,incrGet 标为弃用(上下文数据为型只能由输入侧决定)
  • 调整solon-flowCondition 更名为 ConditionDesc
  • 调整solon-flowTask 更名为 ConditionDesc
  • 调整solon-flowGraphDecl 重命名改为 GraphSpec,NodeDecl 重命名改为 NodeSpec,LinkDecl 重命名改为 LinkSpec
  • 调整solon-flowGraphSpec.parseByText 重命名改为 fromText,parseByUri 重命名改为 fromUri
  • 调整solon-flowGraph.parseByText 重命名改为 fromText,parseByUri 重命名改为 fromUri

兼容变化对照表:

旧名称新名称说明
GraphDeclGraphSpec图定义
GraphDecl.parseByXxxGraphSpec.fromXxx图定义加载
Graph.parseByXxxGraph.fromXxx图加载
LinkDeclLinkSpec连接定义
NodeDeclNodeSpec节点定义
ConditionConditionDesc条件描述
TaskTaskDesc任务描述(避免与 workflow 的概念冲突)
FlowStatefulServiceWorkflowService工作流服务
StatefulTaskTask任务
OperationTaskAction任动工作
TaskTypeTaskState任务状态

FlowStatefulService 到 WorkflowService 的接口变化对照表:

旧名称新名称说明
postOperation(..)postTask(..)提交任务
postOperationIfWaiting(..)postTaskIfWaiting(..)提交任务
evel(..)/执行
stepForward(..)/单步前进
stepBack(..)/单步后退
/getState(..)获取状态

新特性预览:Graph 硬编码方式(及修改能力增强)

//硬编码Graphgraph=Graph.create("demo1","示例",spec->{spec.addStart("start").title("开始").linkAdd("01");spec.addActivity("n1").task("@AaMetaProcessCom").linkAdd("end");spec.addEnd("end").title("结束");});//修改GraphgraphNew=Graph.copy(graph,spec->{spec.getNode("n1").linkRemove("end").linkAdd("n2");//移掉 n1 连接;改为 n2 连接spec.addActivity("n2").linkAdd("end");});

新特性预览:FlowContext:lastNodeId (计算的中断与恢复)。参考:https://solon.noear.org/article/1246

flowEngine.eval(graph,context.lastNodeId(),context);//...(从上一个节点开始执行)flowEngine.eval(graph,context.lastNodeId(),context);

新特性预览:WorkflowService(替代 FlowStatefulService)

WorkflowServiceworkflow=WorkflowService.of(engine,WorkflowDriver.builder().stateController(newActorStateController()).stateRepository(newInMemoryStateRepository()).build());//1. 取出任务Tasktask=workflow.getTask(graph,context);//2. 提交任务workflow.postTask(task.getNode(),TaskAction.FORWARD,context);

二、特色展示

1、采用 yaml 或 json 偏平式编排格式

偏平式编排,没有深度结构(所有节点平铺,使用 link 描述连接关系)。配置简洁,关系清晰

# c1.ymlid:"c1"layout:-{id:"n1",type:"start",link:"n2"}-{id:"n2",type:"activity",link:"n3"}-{id:"n3",type:"end"}

还支持简化模式(能自动推断的,都会自动处理),具体参考相关说明

# c1.ymlid:"c1"layout:-{type:"start"}-{task:""}-{type:"end"}

2、表达式与脚本自由

# c2.ymlid:"c2"layout:-{type:"start"}-{when:"order.getAmount() >= 100",task:"order.setScore(0);"}-{when:"order.getAmount() > 100 && order.getAmount() <= 500",task:"order.setScore(100);"}-{when:"order.getAmount() > 500 && order.getAmount() <= 1000",task:"order.setScore(500);"}-{type:"end"}

3、元数据配置,为扩展提供了无限空间

元数据主要有两个作用:(1)为任务运行提供配置支持(2)为视图编辑提供配置支持

# c3.ymlid:"c3"layout:-{id:"n1",type:"start",link:"n2"}-{id:"n2",type:"activity",link:"n3",task:"@MetaProcessCom",meta:{cc:"demo@noear.org"}}-{id:"n3",type:"end"}

通过组件方式,实现元数据的抄送配置效果

@Component("MetaProcessCom")publicclassMetaProcessComimplementsTaskComponent{@Overridepublicvoidrun(FlowContextcontext,Nodenode)throwsThrowable{Stringcc=node.getMeta("cc");if(Utils.isNotEmpty(cc)){//发送邮件...}}}

4、事件广播与回调支持

广播(即只需要发送),回调(即发送后要求给答复)

id:f4layout:-task:|//发送事件 context.eventBus().send("demo.topic", "hello"); //支持泛型(类型按需指定,不指定时为 object)-task:|//调用事件(就是要给答复) String rst = context.eventBus().<String, String>call("demo.topic.get", "hello").get(); System.out.println(rst);

5、支持驱动定制(就像 jdbc 的驱动机制)

通过驱动定制,可方便实现:

  • 工作流(workflow), 用于办公审批型(有状态、人员参与)的编排场景
  • 规则流(ruleflow)
  • 数据流(dataflow)
  • AI流(aiflow)
  • 等…
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/28 23:09:44

CRUD Admin Generator:终极快速构建后台管理系统的完整指南

CRUD Admin Generator&#xff1a;终极快速构建后台管理系统的完整指南 【免费下载链接】crud-admin-generator An open source tool to generate a complete backend from a MySql database. 项目地址: https://gitcode.com/gh_mirrors/cr/crud-admin-generator CRUD A…

作者头像 李华
网站建设 2026/5/29 19:19:53

FoxMagiskModuleManager:让你的Android设备更智能的模块管家

FoxMagiskModuleManager&#xff1a;让你的Android设备更智能的模块管家 【免费下载链接】FoxMagiskModuleManager A module manager for Magisk because the official app dropped support for it 项目地址: https://gitcode.com/gh_mirrors/fo/FoxMagiskModuleManager …

作者头像 李华
网站建设 2026/5/27 11:49:26

nodeppt Mermaid插件实战:从技术小白到图表高手的心路历程

nodeppt Mermaid插件实战&#xff1a;从技术小白到图表高手的心路历程 【免费下载链接】nodeppt This is probably the best web presentation tool so far! 项目地址: https://gitcode.com/gh_mirrors/no/nodeppt 还记得第一次做技术分享时的窘迫吗&#xff1f;面对着台…

作者头像 李华
网站建设 2026/5/29 20:06:55

语音识别模型训练案例:展示PyTorch-CUDA-v2.7的强大算力支持

语音识别模型训练案例&#xff1a;展示PyTorch-CUDA-v2.7的强大算力支持 在当今智能语音交互日益普及的背景下&#xff0c;从智能音箱到车载助手&#xff0c;语音识别系统的响应速度和准确率直接决定了用户体验。然而&#xff0c;支撑这些流畅交互的背后&#xff0c;是动辄数百…

作者头像 李华
网站建设 2026/5/27 20:06:53

终极YouTube广告拦截检测移除指南:免费恢复无广告观看体验

终极YouTube广告拦截检测移除指南&#xff1a;免费恢复无广告观看体验 【免费下载链接】RemoveAdblockThing The intrusive "Ad blocker are not allowed on YouTube" message is annoying. This open-source project aims to address this issue by providing a so…

作者头像 李华
网站建设 2026/5/29 3:32:53

WSL注册失败困扰你?切换至PyTorch-CUDA-v2.7容器化解决方案

WSL注册失败困扰你&#xff1f;切换至PyTorch-CUDA-v2.7容器化解决方案 在深度学习项目开发中&#xff0c;最令人沮丧的时刻往往不是模型不收敛&#xff0c;而是环境根本跑不起来。尤其是当你兴冲冲地准备复现一篇论文或训练一个新模型时&#xff0c;却被 WslRegisterDistribut…

作者头像 李华