Activiti 工作流学习 (三)
Activiti 工作流学习 (三)
雷斯林 发表于1年前
Activiti 工作流学习 (三)
  • 发表于 1年前
  • 阅读 135
  • 收藏 1
  • 点赞 0
  • 评论 0

腾讯云 新注册用户 域名抢购1元起>>>   

上一篇    Activiti 工作流学习(二)

 

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

关键对象

1.      Deployment:流程部署对象,部署一个流程时创建。

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

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

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

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

 

 

七大接口

 

1.      ProcessEngine:流程引擎的抽象,通过它我们可以获得我们需要的一切服务。 

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

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

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): 
这里写图片描述

 

标签: Activiti
共有 人打赏支持
粉丝 7
博文 11
码字总数 5596
×
雷斯林
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: