Activiti入门学习

tech2023-11-13  87

                                                        Activiti介绍

        Activiti5是由Alfresco软件在2010年5月17日发布的业务流程管理(BPM)框架,它是覆盖了业务流程管理、工作流、服务协作等领域的一个开源的、灵活的、易扩展的可执行流程语言框架。Activiti基于Apache许可的开源BPM平台,创始人Tom Baeyens是JBoss jBPM的项目架构师,它特色是提供了eclipse插件,开发人员可以通过插件直接绘画出业务。

        简单来说Activiti属于一个业务流程管理框架,提供了对业务流程的管控,常用于对工作审批、活动流程等项目。例如:最简单的一个请假流程,需要本人写出请假条后交给班主任签字,班主任签字同意后,再交给交给系领导签字。。。。对于Activiti来讲这个流程一旦开始后的不可以提前进入下一步,也不可以后退到上一步。

       1.BPMN和工作流引擎

        BPMN:是指业务流程建模与标注,描述流程的基本符号,相当于可以通过流程图来展示和管控业务流程顺序的规则。

工作引擎:是指ProcessEngine对象,它是整个Activiti业务流程的核心部分,用来对工作流运行时进行监控和管理,以及生成各种数据。

工作流引擎的作用

     先来讲讲ProcessEngine对象是如何产生的。

首先需要创建Activiti配置对象的实例ProcessEngineConfiguration(Activiti的后台是有数据库的支持,在使用之前需要配置Activiti.cfg.xml文件或者直接使用ProcessEngineConfiguration添加数据源参数),里面主要配置相关数据源参数,支持基于配置文件和注解的创建。

方法一

方法二

首先配置Activiti.cfg.xml文件,配置访问数据库的信息。

然后去加载配置文件

在创建好ProcessEngineConfiguration的实例对象后,通过是实例化对象调用buildProcessEngine()方法来获得ProcessEngine对象。然后ProcessEngine 可以产生RepositoryService、RuntimeService、TaskService等服务类,这些服务类提供了以及封装好的方法来对数据库进行增删改查。

2.Activiti生成的数据库

在调用ProcessEngine对象的时候会在数据库中创建多张表,其中的所有表都是以ACT-开头。

 

生成的数据库分类 ACT_RE_*表示repository。 这个前缀的表包含了流程定义和流程静态资源 (图片,规则,等等)。ACT_RU_*表示runtime。 这些运行时的表,包含流程实例,任务,变量,异步任务,等运行中的数据。 Activiti只在流程实例执行过程中保存这些数据, 在流程结束时就会删除这些记录。 这样运行时表可以一直很小速度很快。ACT_ID_*表示identity。 这些表包含身份信息,比如用户,组等等。ACT_HI_*表示history。 这些表包含历史数据,比如历史流程实例, 变量,任务等等。ACT_GE_*通用数据, 用于不同场景下,如存放资源文件。

表结构操作(手动偷来的):

3.1:资源库流程规则表

1)        act_re_deployment        部署信息表

2)        act_re_model               流程设计模型部署表

3)        act_re_procdef             流程定义数据表

3.2:运行时数据库表

1)        act_ru_execution           运行时流程执行实例表

2)        act_ru_identitylink        运行时流程人员表,主要存储任务节点与参与者的相关信息

3)        act_ru_task                   运行时任务节点表

4)        act_ru_variable             运行时流程变量数据表

3.3:历史数据库表

1)        act_hi_actinst               历史节点表

2)        act_hi_attachment          历史附件表

3)        act_hi_comment            历史意见表

4)        act_hi_identitylink         历史流程人员表

5)        act_hi_detail                 历史详情表,提供历史变量的查询

6)        act_hi_procinst              历史流程实例表

7)        act_hi_taskinst              历史任务实例表

8)        act_hi_varinst               历史变量表

3.4:组织机构表

1)     act_id_group           用户组信息表

2)     act_id_info              用户扩展信息表

3)     act_id_membership  用户与用户组对应信息表

4)     act_id_user             用户信息表

这四张表很常见,基本的组织机构管理,关于用户认证方面建议还是自己开发一套,组件自带的功能太简单,使用中有很多需求难以满足

3.5:通用数据表

act_ge_bytearray          二进制数据表

act_ge_property            属性数据表存储整个流程引擎级别的数据,初始化表结构时,会默认插入三条记录,

 

这些表主要是存放流程在执行中产生的数据,可以通过RepositoryService、RuntimeService、TaskService等服务类来对数据库进行CRUD(流程启动后在进行到某一环节时,当这一环节的负责人未进行操作(且有同职位的负责人时)是可以进行改派的,但对于已经执行过的部分流程是无法进行修改的)。

 

 

 

 

 

最新回复(0)