认识工作流- What is Activiti?

阅读文本大概需要 5 分钟。

一、Activiti是什么?

我们前文中提到了工作流的概念。工作流是以任务的形式驱动人处理业务或者驱动业务系统自动完成作业。今天咱们一起再认识一下市面上主流的开源工作流框架:Activiti

Activiti项目是一项新的基于Apache许可的开源BPM平台,从基础开始构建,旨在提供支持新的BPMN 2.0标准,包括支持对象管理组(OMG),面对新技术的机遇,诸如互操作性和云架构,提供技术实现。创始人Tom Baeyens是JBoss jBPM的项目架构师,以及另一位架构师Joram Barrez,一起加入到创建Alfresco这项首次实现Apache开源许可的BPMN 2.0引擎开发中来。

Activiti是一个独立运作和经营的开源项目品牌,并将独立于Alfresco开源ECM系统运行。 Activiti将是一种轻量级,可嵌入的BPM引擎,而且还设计适用于可扩展的云架构。 Activiti将提供宽松的Apache许可2.0,以便这个项目可以广泛被使用,同时促进Activiti BPM引擎和BPMN 2.0的匹配,该项目现正由OMG通过标准审定。

二、Activiti的特点

  1. 数据持久化 它选择了使用mybatis,可以方便使用sql语句执行command ,通过对sql等的优化实现高效的性能要求。
  2. 引擎服务优秀 提供了7个大的服务接口,可以满足不同的业务流程需求。同时支持链式编程编程风格。主要有流程仓库、身份服务、运行时服务、任务服务、表单服务、历史数据服务、引擎管理服务。
  3. 流程设计器 针对使用eclipse 开发工具来说有eclipse designer 插件,方便进行流程设计。
  4. 原生支持srping 原生支持,可以与spring 进行无缝集成,方便管理事务和解析表达式。这点对于使用spring 传统项目开发的同学来说,是一件好的事情。
  5. 分离运行时与历史数据 它继承了jbpm4,在表结构设计方面遵循运行时与历史数据的分离。可以快速读取运行时刻数据,提高数据的存取效率。

三、Activiti在系统集成方面的应用

  • 与ESB 整合。例如MULE
  • 与规则引擎整合。如JBOSS drools
  • 与其它系统框架整合在一起,比如 spring 框架,生成开发类似 OA办公自动化系统。

四、Activiti框架和组件

一个完整框架主要有如下这些部分,它们之间是关联和交互的。

  • 核心模块:核心模块的作用主要是提供对BPMN规范的解析、执行、创建、管理、查询历史记录并根据生成报表。
  • 模型设计器:由开发人员打包各种资源,然后在系统管理中规范流程定义。
  • 可视化设计:具体的流程引擎按照事先定义的流程处理路线以任务驱动的方式执行业务流程。进行流程定义。
  • 仓库管理:管理仓库、用户、组、启动流程、任务办理。
  • 交互:主要是进行JSON交互。

五、Activiti5与jBPM5技术组成对比

对比目前市面上两个主流的工作流程框架说明:

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

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

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

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

Activiti依赖的第三方jar包较少,常用的是:activiti-engine-5.91.jar,activiti-spring-5.9.jar。而JBPM则依赖jar较多。但这不是重点的区别,相对来说工程大小可能不同了。

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

Activiti提供了Deploy机制

九、总结

本节主要认识工作流和Activiti,了解什么是工作流,什么是Activiti。Activiti有什么特点、它主要应用在哪些地方、它的框架组成是什么样子的,以及从市面上主流的工作流框架解决对比了Activiti和jbpm两个框架的不同和优缺点。方便大家更加直接了解Activiti。希望这篇文章给大家的学习带来帮助。更多工作流的文章,请陆续进行关注。

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

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

原文发表时间:2018-01-24

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

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏SDNLAB

SDN实战团分享(二十四):Midonet简介

Midonet是日本的Midokura公司开源出来的Neutron组网方案。Midokura早在2010年就开始做云中的网络虚拟化,他们最开始做Midonet是...

34711
来自专栏数据和云

【深入解析】DRM和read-mostly locking

作者简介 ? 何剑敏 Oracle ACS华南区售后团队,首席技术工程师。多年从事第一线的数据库运维工作,有丰富项目经验、维护经验和调优经验,专注于数据库的整...

2735
来自专栏性能与架构

大型图片网站 500px 是如何处理图片的?

500px 是一个国际大型图片类网站,致力于摄影分享、发现、售卖的专业平台 需要处理海量用户上传的图片,并且有N倍于上传量的图片展示量 根据一年前公布的数据,5...

3437
来自专栏FreeBuf

scapy在wlan中的应用

Scapy 又是scapy,这是python的一个网络编程方面的库,它在wlan中也有很强大的应用。一般我们买块网卡,然后aircrack-ng套件爆破一下邻居...

21410
来自专栏散尽浮华

网站每日PV/IP统计/总带宽/URL统计脚本分享(依据网站访问日志)

在平时的运维工作中,我们运维人员需要清楚自己网站每天的总访问量、总带宽、ip统计和url统计等。 虽然网站已经在服务商那里做了CDN加速,所以网站流量压力都在前...

1946
来自专栏微信公众号:Java团长

Java软件工程师就业思维图(2016年版)

想要成为合格的Java程序员或工程师到底需要具备哪些专业技能,在面试之前到底需要准备哪些东西呢?面试时面试官想了解你的什么专业技能,以下都是一个合格JAVA软件...

1294
来自专栏码匠的流水账

2017年终总结

又到了写年终总结的时候了。每当这个时候思绪总是翻江倒海,因为太久没有反思和总结的缘故,一年才总结一次,确实是有点久,欠的账的太多,梳理起来有点费劲。这里依旧还是...

421
来自专栏FreeBuf

深入了解VoWiFi安全性

T-mobile开创了智能手机嵌入原生无缝支持WiFi调用的技术。这种集成WiFi调用功能的技术与当今大部分智能手机供应商所采用的方案一样。T-mobile在2...

17310
来自专栏SDNLAB

SDDC新生力量:F5 BIG-IP & VMware NSX

过去10年中,企业为了享受软件计算和存储资源的灵活性迅速地接纳了网络虚拟化。SDN和虚拟化新用例软件定义数据中心(SDDC)越来越受欢迎。随着F5和VMware...

3269
来自专栏Laoqi's Linux运维专列

四大Java EE容器(Tomcat、JBoss、Resin、Glassfish)之简单比较(转)

3179

扫描关注云+社区