当前位置: 首页 > news >正文

常见的工作流编排引擎

常见工作流框架:微服务编排引擎

工作流框架还是比较多的,按照语言分类的话,有

Java: jBPM、Activiti、SWF

PHP: Tpflow、PHPworkflow

Go: Cadence(Cadence由Uber开发并开源,Maxim Fateev是Cadence的主架构师)、Temporal(Maxim Fateev为了推广Workflow编排引擎的商业化,另立门户创建了Temporal)、Fastflow 

工单系统调研:https://zhihu.kdocs.cn/l/ccLQYQzyjX9L?from_wecom=1#

特点缺点可视化界面语言开源

jBPM

  • 始祖级
  • 依赖服务差(如持久化-hibernate)
java
Activiti
  • 顺序流,一步一步执行,节点间有先后顺序
  • Activiti Custom Stencils – BPMN Editor
  • 可以绘制流程图
  • 可拓展
  • 需掌握Java语言 BPMN XML语法和图形符号
  • 审批等操作都是在一个大的长事务里面去执行,一个审批操作会设计到操作多张表,如果处理不好的话性能会影响比较大
java开源,star: 9.3k,近2天有更新
liteflow
  • 轻量
  • 逻辑驱动的编排
图形化界面java开源,star: 1.7k,近1周有更新

n8n(工作流)

docker run -it --rm --name n8n -p 5678:5678 -v ~/.n8n:/home/node/.n8n docker.n8n.io/n8nio/n8n

  • 简单,低代码运行
  • 可拓展
  • 节点是黑盒,报错不可观测
  • 官方支持了很多打包节点,但对按业务来看基本不能直接复用
  • 收费
图形化界面,关联节点,事件触发js

开源,star: 29.1k,近1天有更新

Temporal

Cadence

  • 支持重入、取消、超时控制、等待回调
  • 提供工作流河代码执行状态完整可见
  • 中心化状态机+事件溯源模式

  • 支持横向拓展
  • 偏底层,需要自己实现DSL和对应的可视化UI
  • 需按固定格式编写代码
图形化界面,可以清楚的知道上下文golang

开源,star: 6.8k,近1天有更新

Fastflow
  • 轻量、支持水平扩容
  • 开箱即用、低代码
  • DAG 模式
golang开源,star: 108,近三月有更新

flowable

  • 从 activiti6 中分裂出来的,在其基础上研发了 DMN 支持,BPEL 支持等
  • 大力发展其商业版产品,开源版本维护不及时,部分功能已经不再开源版发布,比如表单生成器(表单引擎)、历史数据同步至其他数据源、ES 等
java开源版本维护滞留
Camunda
  • 基于 activiti5,保留了 PVM
  • 支持流程实例的迁移
  • bug 较多,维护周期长
  • 开源版本仅支持部分能力且不承诺任何保障
公司内部的工作流编排相关使用分析
需求场景工作流选型产品特点
Airbyte 数据同步引擎Temporal
  • 社区活跃,生态完善,有不少国外公司在用
  • 提供引擎 + web-ui 平台,可以开箱即用或者做少量的定制
  • 针对数据同步场景,具备非常好的水平扩展能力

云效部署、流水线发布

  • 适用于流水线的工作流引擎选型
camunda (Activiti 5 衍生)

BPMN2.0(图形编排能力)

  • Web-based tooling for BPMN, DMN, CMMN, and Forms | bpmn.io
  • https://www.omg.org/spec/BPMN/2.0/PDF
  • https://www.cnblogs.com/jiligalaer/p/4090118.html
  • https://www.cnblogs.com/garfieldcgf/p/13469519.html

zelus 定时任务调度平台

  • https://zhihu.kdocs.cn/l/cumPW2jYEOGE
  • 建设知乎云原生任务调度平台
依赖的是k8s 的组件 + argo-workflow
  • GitHub - argoproj/argo-workflows: Workflow Engine for Kubernetes

研发效能工具

  •  工作流引擎技术调研
activiti可以绘制流程图

RFC - 流程编排 - bpmn-js(LCDP)前端部分的流程编排方案

  • 工作流编排引擎技术RFC
  • BFF工作流编排引擎设计拆分

bpmn-js

  • 官网:Web-based tooling for BPMN, DMN, CMMN, and Forms | bpmn.io
  • DEMO:BPMN Editor | bpmn-js modeler Demo | demo.bpmn.io

有不错的扩展性和用户体验

  • 写在开始 | bpmn-js-doc

理解策略识别调度服务

dag 调度策略(有向无环图)

自研

  • 用户可以利用系统预置的节点以及自定义的节点组织流程。通过工作台、节点输出以及边的属性等获取组装参数,最终完成整个流程。
  • 会启动一个容器组来进行消息监听和消息处理,中心化的(产生的原因:区块链-公链)

星河 流程编排 SDK(StarRiver)

  • 反作弊 流程编排使用手册

如何选型

针对我们自身的开发效率、支撑能力、稳定性

  • 多异步事件

  • 服务可靠性低

  • 流程长繁杂

  • 复杂状态

工作流通常适用于,有状态的、异步、长时间执行等特性的业务场景,比较典型的场景包括

  1. 视频、音频、图片处理工作流

  2. 订单、审批流程

  3. 数据处理流水线

  4. 自动化运维

http://www.lryc.cn/news/259355.html

相关文章:

  • 期末总复习(重点!!!)
  • input 获取焦点后样式的修改
  • 持续集成交付CICD:Jenkins使用GitLab共享库实现自动上传前后端项目Nexus制品
  • 50mA、24V、超低 IQ、低压降稳压器
  • 【Python测试开发】文件上传操作
  • 深兰科技AI医疗健康产品获3000台采购订单
  • 金鸣表格文字识别的图片转word,模块不同,效果有何差异?
  • Qt Creator设置IDE的字体、颜色、主题样式
  • SpringBootWeb入门、HTTP协议、Web服务器-Tomcat
  • 【Jenkins】Centos环境安装Jenkins(通过rpm安装)
  • 华为数通---配置基本QinQ示例
  • 利用poi实现将数据库表字段信息导出到word中
  • 深入浅出分析kafka客户端程序设计 ----- 生产者篇----万字总结
  • 粗到细语义(Coarse-to-Fine Semantics)
  • 小程序开发实战案例四 | 小程序标题栏如何设置
  • Flutter在Visual Studio Code上首次创建运行应用
  • 如何用ChatGPT分析恶意软件?
  • 【Axure高保真原型】能增删改的树形表格
  • 前端打包工具之Webpack5
  • linux设置环境变量
  • vue中对pdf文件和路径的处理
  • Socks5与代理IP技术探析:构建安全高效的网络通信
  • 【lesson13】MySQL表的基本操作之create(创建),update(更新)和replace(替换)
  • SQL进阶 | HAVING子句
  • 【Marp】基于Markdown-Marp快速制作PPT
  • 微服务项目部署
  • vite+TypeScript+vue3+router4+Pinia+ElmPlus+axios+mock项目基本配置
  • 【rabbitMQ】模拟work queue,实现单个队列绑定多个消费者
  • pdf转png的两种方法
  • 【起草】1-2 讨论 ChatGPT 在自然语言处理领域的重要性和应用价值