activiti7流程部署
接着上一篇文章activiti7+springboot2.1.x环境搭建继续讲。
流程图绘制
在上一篇文章当中提到需要需要在idea中安装actiBPM插件,但是在之前的环境搭建过程中并没有使用,本文中将使用idea的actiBPM插件来绘制bpmn2的流程图。bpmn2是工作流的一个标准规范,不光activiti要满足这个规范,其它的一些标准的工作流产品也一样需要满足和实现这个规范。
开始
这里我们将要实现一个公司里面一个简单的请假流程。流程分为四个步骤
- 一个员工提交请假申请
- 上级主管对个请假申请做一个审批
- 总经理审批
-
人事部审批
这里先看下这个项目的基本结构
具体的实现
- 现在resourcees目录下面创建一个processs文件夹,用来专门放置工作流相关的文件(bpmn文件和图片文件)。
-
创建工作流文件命名为:holiday.bpmn,如果正常安装actiBPM插件,在新建文件时候就可以正常选择创建bpmn文件。
-
绘制流程图,先绘制开始,然后绘制三个UserTask,最后结束。将各个流程节点连接起来。在按照下面的步骤操作。
-
将holiday.bpmn流程定义文件重命名为holiday.xml
4.再将holiday.xml文件重命名为holiday.bpmn。 至此一个简单的请假流程图就绘制完成。
流程部署
在上一篇文章中已经获取将processEngine,runtimeService,taskService,repositoryService,historyService等相关activiti工作流需要用到的注解初始化到了spring的容器中。所以在这里只需要直接调用即可。
- java接下来就是java代码调用
@Autowired
private RuntimeService runtimeService;
@Autowired
private TaskService taskService;
@Autowired
private ProcessEngine processEngine;
@Autowired
private RepositoryService repositoryService;
@Autowired
private HistoryService historyService;
/**
* 部署一个简单的流程示例
*/
@Override
public void deployAProcess() {
repositoryService.createDeployment()
.addClasspathResource("process/holiday.bpmn")
.addClasspathResource("process/holiday.png")
.name("请假流程")
.deploy();
}
- 然后写一个测试类,调用这个方法
package com.zhang.activity.service;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;
/**
* @author zhanghl
*/
@RunWith(SpringRunner.class)
@SpringBootTest
public class ActivityServiceImplTest {
@Autowired
private ActivityService activityService;
@Test
public void deployAProcess() {
activityService.deployAProcess();
}
}
-
运行测试方法,部署流程。(注意如果运行测试类报VERSION_找不到这个异常,则自己手动在act_re_deployment这个表VERSION_,PROJECT_RELEASE_VERSION_,ENGINE_VERSION_添加三个属性)
- 查看数据库表,流程部署完成后会在数据的,act_re_procdef,act_re_deployment,act_ge_byteArray三张表生成数据。
-
act_re_procdef流程定义表,有数据一条数据。
-
act_re_deployment流程部署表,有一条数据。
- act_ge_byteArray表,有两条数据,由于有两个文件(holiday.bpmn、holiday.png)
扩展,activiti7工作流表名的含义简单解释
表名默认以“ACT_”开头,并且表名的第二部分用两个字母表明表的用例,而这个用例也基本上跟Service API匹配。
ACT_GE_* : “GE”代表“General”(通用),用在各种情况下;
ACT_HI_* : “HI”代表“History”(历史),这些表中保存的都是历史数据,比如执行过的流程实例、变量、任务,等等。Activit默认提供了4种历史级别:
ACT_ID_* : “ID”代表“Identity”(身份),这些表中保存的都是身份信息,如用户和组以及两者之间的关系。如果Activiti被集成在某一系统当中的话,这些表可以不用,可以直接使用现有系统中的用户或组信息;
ACT_RE_* : “RE”代表“Repository”(仓库),这些表中保存一些‘静态’信息,如流程定义和流程资源(如图片、规则等);
ACT_RU_* : “RU”代表“Runtime”(运行时),这些表中保存一些流程实例、用户任务、变量等的运行时数据。Activiti只保存流程实例在执行过程中的运行时数据,并且当流程结束后会立即移除这些数据,这是为了保证运行时表尽量的小并运行的足够快;
表分类 | 表名称 | 表含义 |
---|---|---|
act_evt_log | 事件处理日志表 | |
一般数据 | act_ge_bytearray | 通用的流程定义和流程资源 |
act_ge_property | 系统相关属性 | |
流程历史记录 | act_hi_actinst | 历史的流程实例 |
act_hi_attachment | 历史的流程附件 | |
act_hi_comment | 历史的说明性信息 | |
act_hi_detail | 历史的流程运行中的细节信息 | |
act_hi_identitylink | 历史的流程运行过程中用户关系 | |
act_hi_procinst | 历史的流程实例 | |
act_hi_taskinst | 历史的任务实例 | |
act_hi_varinst | 历史的流程运行中的变量信息 | |
用户用户组表 | act_id_group | 身份信息-组信息 |
act_id_info | 身份信息-组信息 | |
act_id_membership | 身份信息-用户和组关系的中间表 | |
act_id_user | 身份信息-用户信息 | |
act_procdef_info | 死信任务 | |
流程定义表 | act_re_deployment | 部署单元信息 |
act_re_model | 模型信息 | |
act_re_procdef | 已部署的流程定义 | |
运行实例表 | act_ru_deadletter_job | 执行失败任务表 |
act_ru_event_subscr | 运行时事件 | |
act_ru_execution | 运行时流程执行实例 | |
act_ru_identitylink | 运行时用户关系信息 | |
act_ru_job | 运行时作业 | |
act_ru_suspended_job | 运行时暂停任务 | |
act_ru_task | 运行时任务 | |
act_ru_timer_job | 运行时定时任务 | |
act_ru_variable | 运行时变量表 |
具体的表结构及详细介绍可参考 Activiti数据库表结构 里面有详细的每个表介绍。