Activiti,Flowable,Camunda流程引擎对比

1 简介

1.1 发展历史

        市场上比较有名的开源流程引擎有osworkflow、jbpm、activiti、flowable、camunda。其中:Jbpm4、Activiti、Flowable、camunda四个框架同宗同源,祖先都是Jbpm4,开发者只要用过其中一个框架,基本上就会用其它三个。osworkflow目前功能简单,目前已处于不活跃状态,此处就不展开描述了。       

1.2 官网

1.3 术语

  • BPMN(Business Process Modeling Notation)业务流程建模与符号
  • CMMN(Case Management Model and Notation) 案例管理模型与符号
  • DMN(Decision Model and Notation) 决策模型与符号
  • 表单引擎(Form Engine) 

1.4 工作流引擎对比

 1.5 流程引擎选型

1.5.1 JBPM

        JBPM 是一套灵活的商业进程管理 (BPM) 套件。轻量、开源(基于Apache License 2.0) 、使用Java实现。你可以用于商业进程与案例整个生命周期中的建模、执行与监控。

      JBPM由JBoss公司开发,目前最高版本JPBM7,不过从JBPM5开始已经跟之前不是同一个产品了,JBPM5的代码基础不是JBPM4,而是从Drools Flow重新开始。

    JBPM自从版本五后,便重启炉灶,完全抛弃了JBMP4的代码基础,重新基于drools进行了实现。JBPM5,JBPM6似乎缺少一个合格的系统架构师,其接口设计匪夷所思,基本上是按照drools的接口再提供了一套JBPM接口,同名的接口,实现类不断重复出现,代码体系十分混乱。

    基于Drools Flow技术在国内市场上用的很少,所有不建议选择jBPM5以后版本。

    JBPM5,JBPM6是一个巨大的失败,使用drools规则引擎来实现工作流引擎听起来是一个很酷的概念,但JBPM开发团队显然没有很好地去掌控好整个架构的变化。因此选择activiti作为工作流引擎至少在可见的几年间都是正道,今后需要实现规则库时,再单独引入drools工具包,相信drools会是一个比JBPM靠谱的工具。

    jBPM4诞生的比较早,后来JBPM4创建者Tom Baeyens离开JBoss后,加入Alfresco后很快推出了新的基于jBPM4的开源工作流系统Activiti, 另外JBPM以hibernate作为数据持久化ORM也已不是主流技术,JBPM不是最佳选择

  1. jBPM3是一个完整的工作流系统实现,面向开发人员,目的在于简化对组织核心流程进行支撑的软件创建,不支持标准。
  2. jBPM4引入PVM,使其拥有更强大的扩展性,同时增加BPMS特性,这些特性包括了对BPMN的支持、面向业务人员的Web建模器和简单统计分析功能的加入。
  3. jBPM5基于原先的Drools Flow,支持BPMN,通过与Drools的合并支持BAM,通过内容仓库增加对流程可视化的支持。由于放弃了jBPM4的PVM,引擎的可扩展性受到损害,并且不再支持jPDL。

1.5.2 Activiti

        Activiti由Alfresco软件开发,目前最高版本v7.7.0。

        Activiti的版本比较复杂,有Activiti5、Activiti6、Activiti7几个主流版本,选型时让人晕头转向,有必要先了解一下Activiti这几个版本的发展历史。

        Activiti5和Activiti6的核心leader是Tijs Rademakers,由于团队内部分歧,在2017年时Tijs Rademakers离开团队,创建了后来的Flowable, Activiti6以及Activiti5代码已经交接给了 Salaboy团队, Activiti6以及Activiti5的代码官方已经暂停维护了

        Salaboy团队目前在开发Activiti7框架,Activiti7内核使用的还是Activiti6,并没有为引擎注入更多的新特性,只是在Activiti之外的上层封装了一些应用。结论是Activiti谨慎选择

 1.5.3 Flowable

        Flowable基于activiti6衍生出来的版本,flowable目前开源最新版本是v6.7.2。

        开发团队是从activiti中分裂出来的,修复了一众activiti6的bug,并在其基础上研发了DMN支持,BPEL支持等等,相对开源版,其商业版的功能会更强大。

        以flowable6.4.1版本为分水岭,大力发展其商业版产品,开源版本维护不及时,目前已一年没有进行更新,部分功能已经不再开源版发布,比如表单生成器(表单引擎)、历史数据同步至其他数据源、ES、支持mongodb数据库等。

1.5.4 Camunda

        Camunda基于Activiti5,所以其保留了PVM,最新版本v8.1.5,保持每年发布2个小版本的节奏,开发团队也是从activiti中分裂出来的,发展轨迹与flowable相似,同时也提供了商业版,不过对于一般企业应用,开源版本也足够了,
选择Camunda的理由:
(1)通过压力测试验证Camunda BPMN引擎性能和稳定性更好,性能对比Flowable提升最小10%,最大39%,而且Camunda无报错,Flowable有报错,Camunda在高并发场景下稳定性更好。
(2)功能比较完善,除了BPMN,Camunda还支持企业和社区版本中的CMMN(案例管理)和DMN(决策自动化)。Camunda不仅带有引擎,还带有非常强大的工具,用于建模,任务管理,操作监控和用户管理,所有这些都是开源的。


2 流程设计器选型

        对于低代码平台中的流程可视化,流程设计器是重要的支撑工具,目前市场上比较主流的流程设计器有bpmn-js、mxGraph、Activiti-Modeler、flowable-modeler。

2.1 官网 

2.2 选型 

2.2.1 bpmn-js

        bpmn-js 是 BPMN 2.0 渲染工具包和 Web 模型。bpmn-js 正在努力成为 Camunda BPM 的一部分。

        bpmn-js 使用 Web 建模工具可以很方便的构建 BPMN 图表,可以把 BPMN 图表嵌入到你的项目中,容易扩展。bpmn-js是基于原生js开发,支持集成到vue、react等开源框架中

2.2.2  mxGraph

        mxGraph是一个强大的JavaScript流程图前端库,可以快速创建交互式图表和图表应用程序。

        国内外著名的ProcessOne和draw.io都是使用该库创建的强大的在线流程图绘制网站. 由于mxGraph是一个开放的js绘图开发框架,我们可以开发出很炫的样式,或者完全按照项目需求定制。

2.2.3 Activiti-Modeler

        Activiti 开源版本中带了web版流程设计器,在Activiti-explorer项目中有Activiti-Modeler,优点是集成简单,开发工作量小,缺点是界面不美观,用户体验差。

2.2.4 Flowable-Modeler

        Flowable开源版本中带了web版流程设计器,展示风格和功能基本跟Activiti-Modeler一样,优点是集成简单,开发工作量小,缺点是界面不美观,用户体验差。

3 选型推荐

        推荐大家使用Camunda+bpms-js组合,笔者因工作需要,后续将从事这方面的开发,后续针对Camunda的开发再出系列博客进行说明


4 参考资料

https://lowcode.blog.csdn.net/article/details/109030329

Activiti、Flowable和Camunda用哪个会比较好? - 知乎

https://lowcode.blog.csdn.net/article/details/109121092

工作流的基础知识梳理 - 知乎

activiti与flowable的区别_分享牛的博客-CSDN博客_flowable activiti

flowable camunda activiti 功能对比 - 腾讯云开发者社区-腾讯云

Activiti7.1, jBPM7.25, Camunda, Flowable6.3技术组成对比_haysong的博客-CSDN博客_flowable和jbpm

常见的工作流引擎(osworkflow、jbpm、activiti、flowable、camunda)比较_风情客家__的博客-CSDN博客_工作流引擎对比

  • 3
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
### 回答1: ActivitiFlowable都是基于BPMN 2.0标准的开源工作流引擎,它们的核心功能都是提供流程定义、流程实例管理、任务管理、历史数据管理等功能。但是,它们在一些方面有所不同。 1. 项目背景:Activiti最初是由Alfresco公司开发的,后来由Camunda公司维护;Flowable是由Activiti的核心开发者创建的新项目。 2. 功能特性:Flowable相对于Activiti在功能上做了一些增强,比如支持CMMN(Case Management Model and Notation)标准、支持DMN(Decision Model and Notation)标准、支持Form Engine等。 3. 架构设计:Flowable的架构设计更加灵活,支持多种数据库、多种缓存、多种消息队列等,而Activiti的架构设计相对比较固定。 4. 社区活跃度:Flowable相对于Activiti的社区活跃度更高,更新更快,社区支持更好。 总的来说,ActivitiFlowable都是优秀的工作流引擎,选择哪一个取决于具体的需求和场景。 ### 回答2: ActivitiFlowable 之间的比较是一个被广泛讨论的话题,很多人认为这两者在很多方面都非常类似。这很大程度上基于 Flowable 是由 Activiti 的创始人创立的,所以它们有很多共同之处,但它们也有很多不同的地方。下面是对 ActivitiFlowable 的比较: 1.架构和组件: ActivitiFlowable 的架构和组件非常相似。它们都支持 BPMN 2.0 和 CMMN,都有流程引擎、任务管理、表单管理、仪表盘、报表、工作流定义等组件。但 Flowable 更加注重微服务方向,提供了和 Spring Boot 集成的组件,更方便快速搭建微服务。 2.性能: ActivitiFlowable 在性能方面都非常卓越,但 Flowable 在某些方面更优秀一些。它的引擎更加灵活和轻量,且可以更好地处理超大型流程。 3.扩展性: Flowable 有更多的插件和扩展支持。通过流程引擎配置文件中的额外配置,Flowable 支持多种企业应用程序集成,如 Activiti API、Camel、Spring Integration 等。Flowable 支持在 BPMN 2.0 流程定义中使用扩展元素,扩展模型并增强其性能。 4.文档和社区支持: 与 Activiti 相比,Flowable 有更好的文档支持和社区支持,它的社区对问题的解答和贡献都比 Activiti 社区更积极。 总体来说,ActivitiFlowable 都是优秀的流程引擎,它们之间的差异在很大程度上取决于应用场景和具体需求。企业在选择时,应该根据自己的需求选择合适的流程引擎。 ### 回答3: ActivitiFlowable是两个开源工作流引擎,它们都是在JBPM项目的基础上发展而来,从而成为了高度可扩展和灵活的工作流引擎。下面是它们在一些方面的对比: 1. 开发者背景 Activiti是一个由Alfresco软件公司开发的工作流引擎,这家公司主要为企业提供内容管理解决方案,Activiti作为其开源产品之一。而FlowableActiviti的一个分支,由Activiti的核心开发者从Alfresco公司离职后成立的一家公司开发的。 2. 社区支持 Activiti拥有较大的社区支持,有大量的文档、教程和示例可供参考。而Flowable在社区方面做得并不太好,但由于Activiti的代码库分支出来,因此它们的功能在很大程度上是相同的。 3. 功能和支持 ActivitiFlowable都支持BPMN 2.0标准。然而,FlowableActiviti提供了更多的功能,例如CMMN Case Management模型和DMN规则引擎,这使得FlowableActiviti更加全面。此外,Flowable还提供了一些企业扩展功能,例如模型扩展、LDAP和Active Directory支持等。 4. 性能 ActivitiFlowable都可以在高负载下提供很好的性能,但在某些场景下,Flowable具有更好的性能。Flowable在处理高流量时,使用异步执行可以更好的处理这些流量,这使得Flowable在处理大量并发流程时比Activiti更快速。 5. 价格 Activiti是一个完全免费的开源工作流引擎,企业用户可以自由地使用和修改其代码。而Flowable也是一个免费开源的工作流引擎,同时提供了一些商业扩展功能的订阅服务。 综上所述,ActivitiFlowable都是高度可扩展和灵活的工作流引擎,并且它们之间的差别不大。如果你需要更全面的功能,可以考虑使用Flowable;如果你需要更好的社区支持和更成熟的生态系统,可以选择Activiti。唯一要注意的是,在选择任何引擎时,请先考虑你的业务需求和限制,选择最适合你的工作流引擎

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zfy_220

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值