写这篇文章的目的主要是项目组开发第一次使用总结的一点小经验,不足之处打架多多探讨.
1.什么是工做流?
以请假为例,如今大多公司的后台流程是这样的java
a.邮件提出申请 b.上级回邮件赞成或其余方式 c.上级请假记录 d.月底将请假上缴公司 e.人事录电脑 采用工做流几乎是的公司请假流程是这样的 **员工使用登陆系统--点击请假--上级登陆系统点击容许,就这样,一个请假流程就结束了!** 有人会问,那上级不用向公司提交请假记录?公司不用将记录录入电脑?答案是,用的。可是这一切的工做都会在上级点击容许后自动运行! 这就是工做流技术。 Georgakopoulos给出的工做流定义是:工做流是将一组任务组织起来以完成某个经营过程:定义了任务的触发顺序和触发条件,每一个任务能够由一个或多个软件系统完成,也能够由一个或一组人完成,还能够由一个或多我的与软件系统协做完成!
2、 工做流技术的优势数据库
从上面的例子,很容易看出框架
工做流系统,实现了工做流程的自动化,提升了企业运营效率、改善企业资源利用、提升企业运做的灵活性和适应性、提升量化考核业务处理的效率、减小浪费(时间就是金钱)。异步
而手工处理工做流程,一方面没法对整个流程情况进行有效跟踪、了解,另外一方面不免会出现人为的失误和时间上的延时致使效率低下,特别是没法进行量化统计,不利于查询、报表及绩效评估。ide
3、 Java开发者会为何要学Activity工做流
在Java领域,JBPM和Activity是两个主流的工做流系统,而Activity的出现无疑将会取代JBPM(Activity的开发者就是从Jbpm开发者出来的)。工具
4、 Activity工做流学习要点学习
1个插件spa
在Eclipse中安装Activity插件,让你能够在Eclipse中绘制Activity工做流图插件
1个引擎设计
ProcessEngine对象,Activity工做流引擎。这是Activiti工做的核心。负责生成流程运行时的各类实例及数据、监控和管理流程的运行。
全部的操做都是从获取引擎开始的,因此通常会把引擎做为全局变量
ProcessEngine processEngine =ProcessEngines.getDefaultProcessEngine();
1个配置文件
activiti.cfg.xml。Activiti核心配置文件,配置流程引擎建立工具的基本参数和数据库链接池参数
5种数据库表
Activiti的后台是有数据库的支持,全部的表都以ACT_开头。 第二部分是表示表的用途的两个字母标识。用途也和服务的API对应。
ACTRE*: 'RE'表示repository。 这个前缀的表包含了流程定义和流程静态资源(图片,规则,等等)。
ACTRU*: 'RU'表示runtime。 这些运行时的表,包含流程实例,任务,变量,异步任务,等运行中的数据。 Activiti只在流程实例执行过程当中保存这些数据,在流程结束时就会删除这些记录。 这样运行时表能够一直很小速度很快。
ACTID*: 'ID'表示identity。 这些表包含身份信息,好比用户,组等等。
ACTHI*: 'HI'表示history。 这些表包含历史数据,好比历史流程实例,变量,任务等等。
ACTGE*: 通用数据,用于不一样场景下,如存放资源文件。
23张表
不一样的表存放不一样方面的数据,有流程定义表、任务结点表、流程变量表、任务历史表等等。
5项Service
不一样的Service类对应不一样的功能。
好比TaskService,是activiti的任务服务类。能够从这个类中获取任务的信息。
而HistoryService,则是activiti的查询历史信息的类。在一个流程执行完成后,这个对象为咱们提供查询历史信息。
7项基本操做
设计流程图(各类组件,如连线、用户任务、网关)
流程定义增删改查
流程变量增删改查
启动流程定义
任务增删改查
完成任务
历史信息查询
总结:只要是这些基本操做可以熟练一下,跟项目框架整合的时候其实很好整合,不会那么吃力!