activity工做流其实很简单

写这篇文章的目的主要是项目组开发第一次使用总结的一点小经验,不足之处打架多多探讨.
1.什么是工做流?
以请假为例,如今大多公司的后台流程是这样的java

    a.邮件提出申请 
    b.上级回邮件赞成或其余方式
    c.上级请假记录
    d.月底将请假上缴公司 
    e.人事录电脑

    采用工做流几乎是的公司请假流程是这样的

    **员工使用登陆系统--点击请假--上级登陆系统点击容许,就这样,一个请假流程就结束了!**

        有人会问,那上级不用向公司提交请假记录?公司不用将记录录入电脑?答案是,用的。可是这一切的工做都会在上级点击容许后自动运行!

            这就是工做流技术。

            Georgakopoulos给出的工做流定义是:工做流是将一组任务组织起来以完成某个经营过程:定义了任务的触发顺序和触发条件,每一个任务能够由一个或多个软件系统完成,也能够由一个或一组人完成,还能够由一个或多我的与软件系统协做完成!

2、 工做流技术的优势数据库

五分钟让你看明白到底什么是Activity --java

从上面的例子,很容易看出框架

工做流系统,实现了工做流程的自动化,提升了企业运营效率、改善企业资源利用、提升企业运做的灵活性和适应性、提升量化考核业务处理的效率、减小浪费(时间就是金钱)。异步

而手工处理工做流程,一方面没法对整个流程情况进行有效跟踪、了解,另外一方面不免会出现人为的失误和时间上的延时致使效率低下,特别是没法进行量化统计,不利于查询、报表及绩效评估。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张表

不一样的表存放不一样方面的数据,有流程定义表、任务结点表、流程变量表、任务历史表等等。

五分钟让你看明白到底什么是Activity --java
5项Service

不一样的Service类对应不一样的功能。

好比TaskService,是activiti的任务服务类。能够从这个类中获取任务的信息。

而HistoryService,则是activiti的查询历史信息的类。在一个流程执行完成后,这个对象为咱们提供查询历史信息。

7项基本操做

设计流程图(各类组件,如连线、用户任务、网关)

流程定义增删改查

流程变量增删改查

启动流程定义

任务增删改查

完成任务

历史信息查询

总结:只要是这些基本操做可以熟练一下,跟项目框架整合的时候其实很好整合,不会那么吃力!

相关文章
相关标签/搜索