Activiti与JBPM概念和差异(整理和汇总)

导读 | Activiti VS JBPM

Activiti概念

一、Activiti特点

1、数据持久化

activiti 设计思想:简洁、快速。使用mybatis

2、原生支持spring

方便集成spring进行事务管理

3、流程设计

eclipse插件安装后有流程设计器,方便使用。

4、引擎接口

提供了7个引擎接口,方便调用

二、Activiti核心组件

  1. Activiti Engine:作为最核心的模块,提供针对BPMN 2.0规范的解析、执行、创建、管理(任务、流程实例)、查询历史记录并根据结果生成报表。
  2. Activiti Modeler:是模型设计器,其并非由Activiti公司所开发,而是由业界认可的Signavio公司赠送的(Signavio原本是收费的产品,现在被免费授权给Activiti用户使用)。适用于业务人员把需求转换为规范流程定义。
  3. Activiti Designer:功能和Activiti Modeler类似,同样提供了基于BPMN 2.0规范的可视化设计功能,但是目前还没有完全支持BPMN规范的定义。适用于开发人员,可以把业务需求人员用Signavio设计的流程定义(XML格式)导入到Designer中,从而让开发人员将其进一步加工成为可以运行的流程定义。
  4. Activiti Kickstart:基于表格的流程设计工具。用Activiti引擎可用的构件(constructs)的子集提供给快速创建“即席(adhoc)”的业务流程。
  5. Activiti Explorer:可以用来管理仓库、用户、组,启动流程、任务办理等。此组件使用REST风格API(目的在于让开发人员快速入门),提供一个基础的设计模型。如果业务简单,也可以直接使用无需开发。还可以作为后台管理员的流程、任务管理系统使用。
  6. Activiti REST:提供Restful风格的服务,允许客户端以JSON的方式与引擎的REST API交互,通用的协议具有跨平台、跨语言的特性。

三、Activiti5与jBPM5技术组成对比

序号

技术组成

Activiti

jBPM5

1

数据库持久层ORM

MyBatis3

Hibernate3

2

持久化标准

JPA规范

3

事务管理

MyBatis机制/Spring事务控制

Bitronix,基于JTA事务管理

4

数据库连接方式

Jdbc/DataSource

Jdbc/DataSource

5

支持数据库

Oracle、SQL Server、MySQL

Oracle、SQL Server、MySQL

6

设计模式

Command模式、观察者模式等

7

内部服务通讯

Service间通过API调用

基于Apache Mina异步通讯

8

集成接口

SOAP、Mule、RESTful

消息通讯

9

支持的流程格式

BPMN2、xPDL、jPDL等

目前仅只支持BPMN2 xml

10

引擎核心

PVM(流程虚拟机)

Drools

11

技术前身

jBPM3、jBPM4

Drools Flow

12

所属公司

Alfresco

jBoss.org

说明:

1、数据库持久层ORM (MyBatis3与Hibernate3)

序号

技术要点

MyBatis3

Hibernate3

1

相对学习的门槛高度

更容易掌握

有一定难度

2

DAO层开发

没有持久化的实现需要维护SQL和结果映射

比较完整的O/R Mapping实现,在开发的过程中你完全可以不用写SQL语句,只要涉及到你的领域模型就可以了,在设计领域模型的时候完全可以使用SOLDI原则。

3

数据库移植性

不同的数据库需要写不同的SQL

基本不需要修改DAO层。因为这层的工作是它本身就实现的

4

缓存机制

不支持缓存

支持缓存

5

SQL优化

可按照实际需求写SQL,减少字段

是持久化对象,输出整个对象,不容易控制

2、持久化和事务管理

jBPM5 使用Hibernate作为数据持久化ORM实现,采用基于JPA/JTA的可插拔的持久化和事务控制规范;

Activiti 使用MyBatis进行底层数据库ORM的管理。使用Spring进行引擎配置以及各个Bean的管理;

四、Activiti与JBPM 相比有更简洁、健壮的接口

JBPM5抛弃了原来JBMP4的代码基础,重新基于drools进行了实现。JBPM5,JBPM6按照drools的接口再提供了一套JBPM接口,同名的接口,实现类不断重复出现,代码体系混乱。

Activiti中提供TaskQuery接口,可以设置各种查询过滤,排序方式,最终通过list方法执行查询

JBPM 的接口代码(查询待办事项接口)

Activiti 的接口代码 (查询待办事项接口)

五、Activiti与JBPM 依赖JAR相对少,比较轻量

Activiti依赖的第三方jar包较少,常用的是:activiti-engine-5.91.jar,activiti-spring-5.9.jar。而JBPM则依赖jar较多。

但这不是重点的区别,相对来说工程大小可能不同了。

六、Activiti与JBPM Activiti支持启动引擎后随时热部署

Activiti提供了Deploy机制

声明:文章属于个人原创,转载请注明文章出处

原文发布于微信公众号 - 全华班(quanhuaban)

原文发表时间:2017-12-11

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏瓜大三哥

aurora 8b/10b精要

aurora 8b/10b协议 TX or RX Only sideband: reset aligned bonded verify 两边采取流控,主要使用这...

1945
来自专栏数据和云

分而治之:从多列到自动Oracle 12.2 分区新特性抢先一览

何剑敏 Oracle ACS华南区售后团队,首席技术工程师 曾供职于中国联通信息计费部、卓望数码、IBM。现供职于Oracle ACS华南区售后团队,首席技术...

2433
来自专栏java达人

Percona5.6.15线程池压力测试

http://www.mysqlperformanceblog.com/2013/03/16/simcity-outages-traffic-control-a...

17810
来自专栏Java帮帮-微信公众号-技术文章全总结

hibernate5新特性展示

摘要: 在hibernate5中,有了一些新的变动: 新引导 API Spatial/GIS 支持 Java 8 支持 扩展 AUTO id 生成支持 命名策略...

2754
来自专栏杨建荣的学习笔记

GoldenGate复制的三个简单测试场景(r10笔记第83天)

今天测试了一下GoldenGate的复制,发现还是有不少的细节之处需要测试,保证可控,而下面做了几个测试也加深了我对OGG的理解。 默认是不支持DDL的,而线上...

3248
来自专栏数据和云

Oracle数据库中最让人匪夷所思的十大问题盘点

数据的世界无奇不有,常常会遇到一些超出常识之外的故障的发生。这就要求广大的DBA要深入了解数据库的内部机制,面对一些奇葩的故障或者问题能够拨开迷雾找到真相。今...

2785
来自专栏老码农专栏

原 荐 ActFramework 在 TEB

1052
来自专栏Android源码框架分析

Android进程保活-自“裁”或者耍流氓

本篇文章是后台杀死系列的最后一篇,主要探讨一下进程的保活,Android本身设计的时候是非常善良的,它希望进程在不可见或者其他一些场景下APP要懂得主动释放,可...

1501
来自专栏杨建荣的学习笔记

复杂SQL性能优化的剖析(二)(r11笔记第37天)

昨天的一篇文章复杂SQL性能优化的剖析(一)(r11笔记第36天) 分析了一个SQL语句导致的性能问题,问题也算暂时告一段落,因为这个语句的执行频率是1...

3479
来自专栏数据和云

深入内核:CBO对于Cost值相同索引的选择

崔华,网名 dbsnake Oracle ACE Director,ACOUG 核心专家 编辑手记:感谢崔华授权我们独家转载其精品文章,也欢迎大家向“Oracl...

3305

扫描关注云+社区