Activiti 工做流学习 (三)

上一篇    Activiti 工做流学习(二)java

 

都是在网上找的一些基本概念,引用的文档比较多比较杂,就不一一列出了。再此表示感谢。sql

关键对象

1.      Deployment:流程部署对象,部署一个流程时建立。数据库

2.      ProcessDefinitions:流程定义,部署成功后自动建立。异步

3.      ProcessInstances:流程实例,启动流程时建立。 ide

4.      Task:任务,在Activiti中的Task仅指有角色参与的任务,即定义中的UserTask。 工具

5.      Execution:执行计划,流程实例和流程执行中的全部节点都是Execution,如UserTask、ServiceTask等。学习

 

 

七大接口

 

1.      ProcessEngine:流程引擎的抽象,经过它咱们能够得到咱们须要的一切服务。 优化

2.      RepositoryService:Activiti中每个不一样版本的业务流程的定义都须要使用一些定义文件,部署文件和支持数据(例如BPMN2.0 XML文件,表单定义文件,流程定义图像文件等),这些文件都存储在Activiti内建的Repository中。RepositoryService提供了对 repository的存取服务。spa

3.      RuntimeService:在Activiti中,每当一个流程定义被启动一次以后,都会生成一个相应的流程对象实例。RuntimeService提供了启动流程、查询流程实例、设置获取流程实例变量等功能。此外它还提供了对流程部署,流程定义和流程实例的存取服务。.net

4.      TaskService: 在Activiti中业务流程定义中的每个执行节点被称为一个Task,对流程中的数据存取,状态变动等操做均须要在Task中完成。TaskService提供了对用户Task 和Form相关的操做。它提供了运行时任务查询、领取、完成、删除以及变量设置等功能。 

5.      IdentityService: Activiti中内置了用户以及组管理的功能,必须使用这些用户和组的信息才能获取到相应的Task。IdentityService提供了对Activiti 系统中的用户和组的管理功能。

6.      ManagementService: ManagementService提供了对Activiti流程引擎的管理和维护功能,这些功能不在工做流驱动的应用程序中使用,主要用于Activiti系统的平常维护。 

7.      HistoryService: HistoryService用于获取正在运行或已经完成的流程实例的信息,与RuntimeService中获取的流程信息不一样,历史信息包含已经持久化存储的永久信息,并已经被针对查询优化。

 

BPMN 

业务流程建模与标注(Business Process Model and Notation,BPMN) ,描述流程的基本符号,包括这些图元如何组合成一个业务流程图(Business Process Diagram)

 

数据库


Activiti数据库支持: 
Activiti的后台是有数据库的支持,全部的表都以ACT_开头。 第二部分是表示表的用途的两个字母标识。 用途也和服务的API对应。 
ACT_RE_*: ‘RE’表示repository。 这个前缀的表包含了流程定义和流程静态资源 (图片,规则,等等)。 
ACT_RU_*: ‘RU’表示runtime。 这些运行时的表,包含流程实例,任务,变量,异步任务,等运行中的数据。 Activiti只在流程实例执行过程当中保存这些数据, 在流程结束时就会删除这些记录。 这样运行时表能够一直很小速度很快。 
ACT_ID_*: ‘ID’表示identity。 这些表包含身份信息,好比用户,组等等。 
ACT_HI_*: ‘HI’表示history。 这些表包含历史数据,好比历史流程实例, 变量,任务等等。 
ACT_GE_*: 通用数据, 用于不一样场景下,如存放资源文件。

 

 

表结构操做: 


资源库流程规则表 
1) act_re_deployment 部署信息表 
2) act_re_model 流程设计模型部署表 
3) act_re_procdef 流程定义数据表 
运行时数据库表 
1) act_ru_execution 运行时流程执行实例表 
2) act_ru_identitylink 运行时流程人员表,主要存储任务节点与参与者的相关信息 
3) act_ru_task 运行时任务节点表 
4) act_ru_variable 运行时流程变量数据表 
历史数据库表 
1) act_hi_actinst 历史节点表 
2) act_hi_attachment 历史附件表 
3) act_ih_comment 历史意见表 
4) act_hi_identitylink 历史流程人员表 
5) act_hi_detail 历史详情表,提供历史变量的查询 
6) act_hi_procinst 历史流程实例表 
7) act_hi_taskinst 历史任务实例表 
8) act_hi_varinst 历史变量表 
组织机构表 
1) act_id_group 用户组信息表 
2) act_id_info 用户扩展信息表 
3) act_id_membership 用户与用户组对应信息表 
4) act_id_user 用户信息表 
这四张表很常见,基本的组织机构管理,关于用户认证方面建议仍是本身开发一套,组件自带的功能太简单,使用中有不少需求难以知足 
通用数据表 
1) act_ge_bytearray 二进制数据表 
2) act_ge_property 属性数据表存储整个流程引擎级别的数据,初始化表结构时,会默认插入三条记录, 

 

 

activiti.cfg.xml(activiti的配置文件) 


Activiti核心配置文件,配置流程引擎建立工具的基本参数和数据库链接池参数。 
定义数据库配置参数: 
 jdbcUrl: 数据库的JDBC URL。 
 jdbcDriver: 对应不一样数据库类型的驱动。 
 jdbcUsername: 链接数据库的用户名。 
 jdbcPassword: 链接数据库的密码。 
基于JDBC参数配置的数据库链接 会使用默认的MyBatis链接池。 下面的参数能够用来配置链接池(来自MyBatis参数): 
 jdbcMaxActiveConnections: 链接池中处于被使用状态的链接的最大值。默认为10。 
 jdbcMaxIdleConnections: 链接池中处于空闲状态的链接的最大值。 
 jdbcMaxCheckoutTime: 链接被取出使用的最长时间,超过期间会被强制回收。 默认为20000(20秒)。 
 jdbcMaxWaitTime: 这是一个底层配置,让链接池能够在长时间没法得到链接时, 打印一条日志,并从新尝试获取一个链接。(避免由于错误配置致使沉默的操做失败)。 默认为20000(20秒)。 
示例数据库配置: 
这里写图片描述

也能够使用javax.sql.DataSource。 (好比,Apache Commons的DBCP): 
这里写图片描述

相关文章
相关标签/搜索