工作流引擎技术介绍-Flowable与Activiti7

以前总听说Activiti作者跑去开发Flowable了,估计大部分人对Activiti和Flowable区别也仅仅知道作者跑了。哈哈哈......但对于Activiti和Flowable以及Camunda的选型对比一直是有人问的,当然我也好奇,就一个作者嘛,一个产品又不是一个人的功劳,产品团队其他人也是有思路的嘛,只要有人,产品就能朝一定方向开发着。但当我看了Activiti7的官网介绍和文档后,不得不感叹人与人之间的想法差距还真是非常大的。

图片

Flowable前面文章有简单的介绍,使用Docker进行部署,很快就能体验Flowable,体验完后都能对Flowable功能有一定认识。网上对比功能点,API的文章还是比较多的。我们这里先看Activiti官网介绍及文档。

01、Activiti7

图片

参考:https://www.gitbook.com/book/activiti/activiti-7-developers-guide/details

Activiti目前版本最新为7.1.0-M15,进入官网首页界面,很清晰的就能看出,Activiti7工作重点在支持云生态。Activiti重点工作在于适配Docker、kubernates,适配Jenkins等devops工具。Activiti 7专注维护流程核心引擎,其他模板IDM (User / Groups / Memberships)身份验证、Forms表单、History Service历史查询服务、Job executor任务执行器、Timers定时器、Email/Notification Service 邮件通知服务等等将被弃用或进行重构,以支持与大多数云基础设施已经提供的第三方组件的集成。

图片

诚然,做这方面是有一定热点,也有一定必要,但个人觉得迷惑的是,流程部分很多功能都没完善,不管是设计器,还是管理端功能,还是引擎核心本身都有很多急需并且必要做的东西,先去做流程云构建,显得有点两边半桶水。体验上不会好。(纯个人看法

图片

依赖:

Activiti Cloud:

<dependencyManagement>
   <dependencies>
     <dependency>
       <groupId>org.activiti.cloud</groupId>
       <artifactId>activiti-cloud-dependencies</artifactId>
       <version>7.1.0-M15</version>
       <scope>import</scope>
       <type>pom</type>
     </dependency>
   </dependencies>
 </dependencyManagement>

Activiti Core


<dependencyManagement>
    <dependencies>
      <dependency>
        <groupId>org.activiti</groupId>
        <artifactId>activiti-dependencies</artifactId>
        <version>7.1.0-M15</version>
        <scope>import</scope>
        <type>pom</type>
      </dependency>
    </dependencies>
  </dependencyManagement>
图片

activiti7很大精力都用在构建云生态,工作重点都放在将服务部署在云上,减少对Activiti依赖的耦合,需要使用Activiti的系统只需要通过调用http接口的方式来实现工作流能力的整合,将工作流业务托管上云。

图片

对于不同人员如专家、开发人员、运维人员、用户、管理者,划分出对应关注的微服务应用。

Activiti Cloud提供部分基础构建模块:

  • Activiti云基础设施

    Activiti Cloud 基础服务将部署网关、身份管理/单点登录、分布式日志/跟踪/监控。

图片
  • Activiti云应用
  1. Activiti Cloud Runtime Bundle: 为业务提供执行运行时支持(如业务流程、任务、决策表、决策树等)。

  2. Activiti Cloud Connectors: 提供与外部系统的双向连接

  3. Activiti Cloud Audit Service: 提供从或多个运行时收集信息(事件)的审计跟踪功能。

  4. Activiti Cloud Query Service: 提供对一个或多个运行时生成的信息的读访问。

  5. Activiti Cloud Notification Service:与Query Service一起,Notification Service使用关于应用程序状态的订阅和推送通知来支持核心构建模块。

图片
  • Activiti云Modeler 推荐使用的设计器

Activiti7开发团队已经完全抛弃了IntelliJ IDEA/Eclipse中的流程插件以及Modeler设计器。开始使用了bpmn.io提供的bpmn-js设计器。目前仅支持元素,空结束事件、空启动事件,用户任务、服务任务、调用活动(callActivity),排他网关和并行网关等。

图片

快速体验:

  • 安装Docker for Desktop 或 Docker Toolbox

  • 安装Docker-compose

  • 安装 GNU Make。通常Linux和Mac系统已经安装了, window系统使用Chocolatey 来安装.

  • 安装 Git Bash 终端 . 通常Linux和Mac系统已经安装了. window可以使用 Chocolatey Git Install 来安装

下载示例代码:

git clone https://github.com/Activiti/activiti-cloud-examples

│  Activiti v7 REST API.postman_collection.json # postman api接口文件
├─docker                                 # docker方式,好像官网没有这方面使用说明了
│  │  enabled_plugins
│  │  frontend-docker-compose.yml        # 前端UI模块
│  │  infrastructure-docker-compose.yml  # 基础模块
│  │  modelling-docker-compose.yml       # 流程图绘制管理模块
│  │
│  └─apps
│          apps.json
│          default-app.json
└─docker-compose                        # docker-compose 方式
        .env                            # 配置文件  --修改ip为本机IP
        activiti-realm.json             # realm 配置文件
        docker-compose.yml              
        Dockerfile
        enabled_plugins
        Makefile
        nginx.conf                      
        README.md

启动服务:

启动设计器:make modeler
访问:http://$DOCKER_IP/modeling  默认账号:modeler/password
启动例子服务:make application
访问keycloak: http://$DOCKER_IP//auth/ 默认账号是 admin/admin

启动所有服务:make all   或者  docker-compose up
图片

测试接口:前面我们了解到,云服务目前以Http接口提供业务支撑。

配置PostMan
1.将 activiti-cloud-examples / Activiti v7 REST API.postman_collection.json
导入到Postman中
2.配置全局变量 gateway、idm、realm
变量名  变量值  变量说明
gateway  http://192.168.1.33  网关地址,即你自己电脑的IP(DOCKER_IP)
idm  http://192.168.1.33  鉴权地址,identity Manager地址
realm  activiti  .env文件中填写的 KEYCLOAK_REALM

3.先调用 keycloak中的接口获取token(访问凭证)。然后就可以调用其他接口
图片

Flowable:

自从Activiti分离开后,Flowable对引擎本身的关注是非常充足的。

  1. CMMN – 案例管理开放标准 (绝对让人眼前一亮,慢慢探索会发现能更灵活的处理很多业务)

  2. DNN - 决策表

  3. 事件流-对Kafka / Confluent、RabbitMQ、AWS SQS还是ActiveMQ/JMS提供开箱即用支持。

  4. 对非关系型数据库提供支持,如MongDB。

  5. 新功能如异步历史、异步执行器、动态注入流程片段。

  6. 流程元素完善和执行性能提升,以及完善引擎管理客户端。

结论:

Activiti7以后,对于流程引擎本身及相关引擎功能关注度并不高,核心很大精力放在构建其云生态环境,而这点,对于中小公司可能并不怎么关心,中小公司关心的还是流程引擎本身的功能与性能,如何快速开展业务开发,以及后续升级运维。这点,Flowable分离出去做了很多完善。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,033评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,725评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,473评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,846评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,848评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,691评论 1 282
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,053评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,700评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,856评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,676评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,787评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,430评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,034评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,990评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,218评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,174评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,526评论 2 343

推荐阅读更多精彩内容