SpringBoot + Activiti 工作流引擎(一、基本概念与环境搭建)
SpringBoot + Activiti一、什么是ActivitiActiviti是一个轻量级的工作流和业务流程管理(BPM)平台,面向业务人员,开发人员和系统管理员。它的核心是用于Java的超快速,坚固的BPMN 2流程引擎。它是开源的,并根据Apache许可进行分发。Activiti可以在任何Java应用程序,服务器,集群或云中运行。它与Spring完美集成,非常轻巧,基于简单的概念。我们可
文章列表:
1. SpringBoot + Activiti 工作流引擎(一、基本概念与环境搭建)
2.SpringBoot + Activiti 工作流引擎(二、流程&任务操作)
SpringBoot + Activiti
前言:什么是工作流?
工作流(Workflow),就是通过计算机对业务流程自动化执行管理。它主要解决的是“使在多个参与者之间按照某种预定义的规则自动进行传递文档、信息或任务的过程,从而实现某个预期的业务目标,或者促使此目标的实现”。
我们可以通俗一点理解,工作流就是将我们日常的流程(例如:请假、报销、岗位调整等流程)规范起来,将工作流当成流程的载体,通过工作流可以实现流程的自动化控制(审批、驳回、转办、挂起、中止等管理工作),让流程管理有据可循。
工作流的具体应用:
- 关键业务流程:订单、报价处理、合同审核、客户电话处理、供应链管理等
- 行政管理类:出差申请、加班申请、请假申请、用车申请、各种办公用品申请、购买申请、日报
周报等凡是原来手工流转处理的行政表单。 - 人事管理类:员工培训安排、绩效考评、职位变动处理、员工档案信息管理等。
- 财务相关类:付款请求、应收款处理、日常报销处理、出差报销、预算和计划申请等。
- 客户服务类:客户信息管理、客户投诉、请求处理、售后服务管理等
- 特殊服务类:ISO 系列对应流程、质量管理对应流程、产品数据信息管理、贸易公司报关处理、
物流公司货物
一、什么是Activiti
Alfresco软件在2010年5月17日宣布Activiti业务流程管理(BPM)开源项目的正式启动,其首席架构师由业务流程管理BPM的专家 Tom Baeyens担任,Tom Bacyens就是原来jbpm的架构师,而jbpm是一个非常有名的工作流引擎,当然activiti也是一个工作流引擎。
Activiti是一个工作流引擎,activiti可以将业务系统中复杂的业务流程抽取出来,使用专门的建模语言(BPMN2.0)进行定义,业务系统按照预先定义的流程进行执行,实现了业务系统的业务流程由activiti进行管理,减少业务系统由于流程变更进行系统升级改造的工作量,从而提高系统的健壮性,同时也减少了系统开发维护成本。
Activiti是一个轻量级的工作流和业务流程管理(BPM)平台,面向业务人员,开发人员和系统管理员。它的核心是用于Java的超快速,坚固的BPMN 2流程引擎。它是开源的,并根据Apache许可进行分发。Activiti可以在任何Java应用程序,服务器,集群或云中运行。它与Spring完美集成,非常轻巧,基于简单的概念。
官方网站:https://www.activiti.org/
二、集成Activiti
2.1 引入依赖
在pom.xml中引入activiti依赖
<dependency>
<groupId>org.activiti</groupId>
<artifactId>activiti-spring-boot-starter-basic</artifactId>
<version>6.0.0</version>
</dependency>
2.2 配置
# 应用名称
spring:
application:
name: springboot-activiti-demo
# activiti
activiti:
#每次应用启动不检查Activiti数据表是否存在及版本号是否匹配,提升应用启动速度
database-schema-update: true
#在项目单独作为一个引擎,本身不部署流程的时候,如果resources目录没有“processes”目录,启动项目报错–找不到processes目录。需要在配置文件中添加以下内容:
check-process-definitions: false
process-definition-location-prefix: classpath:/processes/
process-definition-location-suffixes:
-**.bpmn
-**.bpmn20.xml
#保存历史数据级别设置为full最高级别,便于历史数据的追溯
history-level: full
datasource:
type: com.alibaba.druid.pool.DruidDataSource
url: jdbc:mysql://146.56.192.87:3306/activiti_demo?useUnicode=true&characterEncoding=utf-8&useSSL=false&serverTimezone=UTC&nullCatalogMeansCurrent=true
jdbc-url: jdbc:mysql://127.0.0.1:3306/activiti_demo?useUnicode=true&characterEncoding=utf-8&useSSL=false&serverTimezone=UTC&nullCatalogMeansCurrent=true
username: oyc
password: 111111
driver-class-name: com.mysql.cj.jdbc.Driver
2.3 在启动类加注解,排查SecurityAutoConfiguration配置
@SpringBootApplication(exclude = SecurityAutoConfiguration.class)
2.4 启动项目,会在数据库生成28张表
表说明:
表名默认以“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 | 运行时变量表 |
流程概念和术语:
- 一个ProcessDefinition代表的业务流程。它用于定义流程中不同步骤的结构和行为。
- 部署流程定义意味着将流程定义加载到Activiti数据库中。
- 流程定义主要由BPMN 2.0标准定义,也可以使用Java代码定义它们,定义的所有术语也可用作Java类。
- 一旦我们开始运行流程定义,就可以称为一个流程process。
- processInstance是ProcessDefinition一个执行实例。
- 一个StartEvent与每一个业务流程有关,它表示该流程的切入点,同样,有一个EndEvent表示流程的结束。我们可以定义这些事件的条件。
- 开始和结束之间的所有步骤(或元素)称为任务,任务可以是各种类型的。最常用的任务是UserTasks和ServiceTasks。
顾名思义,UserTasks需要由用户手动执行,另一方面,ServiceTasks配置了一段代码,每当执行到达这段代码时,代码将被执行。
SequenceFlows用来连接任务,我们可以通过它将源元素和目标元素连接起来定义一个SequenceFlows;同样,我们还可以在SequenceFlow上定义条件,这样能在流程中创建条件路径。
有了流程定义,我们可以使用Activiti提供的服务功能进行流程运行。
Activiti提供的服务-7大接口:
- RepositoryService:提供一系列管理流程部署和流程定义的API,帮助我们实现流程定义的部署。此服务会处理与流程定义相关的静态数据。
- RuntimeService:在流程运行时对流程实例进行管理与控制。管理 ProcessInstances(当前正在运行的流程)以及流程变量
- TaskService:对流程任务进行管理,例如任务提醒、任务完成和创建任务等。会跟踪 UserTasks,需要由用户手动执行的任务是Activiti API的核心。我们可以使用此服务创建任务,声明并完成任务,分配任务的受让人等。
- FormService:表单服务。是一项可选服务,它用于定义中开始表单和任务表单。
- IdentityService:提供对流程角色数据进行管理的API,这些角色数据包括用户组、用户及它们之间的关系。管理用户和组。
- HistoryService:对流程的历史数据进行操作,包括查询、删除这些历史数据。我们还可以设置不同的历史级别。
- ManagementService:提供对流程引擎进行管理和维护的服务。与元数据相关,在创建应用程序时通常不需要。
- DynamicBpmnService:帮助我们在不重新部署的情况下更改流程中的任何内容。
源码地址:https://github.com/oycyqr/springboot-learning-demo/tree/master/springboot-activiti
更多推荐
所有评论(0)