Activiti 实战:环境搭建与第一个工作流程的创建
发布时间: 2023-12-24 11:32:24 阅读量: 48 订阅数: 22
# 1. Activiti 简介与概述
### 1.1 Activiti 工作流引擎简介
Activiti 是一个开源的轻量级企业级工作流引擎,使用 Java 编写,可用于管理和执行业务流程。Activiti 提供了一个易于使用的可视化界面,以及丰富的 API 和工具,使开发人员可以轻松地创建、部署和管理各种复杂的工作流程。
### 1.2 Activiti 的优势与特点
- 简单易用:Activiti 提供了直观的可视化界面和简洁的 API,使工作流的设计和开发变得简单易用。
- 轻量级高效:Activiti 是一个轻量级的工作流引擎,具有快速启动和执行的优势,适用于各种规模的项目。
- 强大灵活:Activiti 提供了丰富的扩展和自定义能力,可以按需添加自定义的任务、监听器、表单等,满足不同场景的需求。
- 可视化监控:Activiti 提供了直观的工作流程监控界面,可以实时查看流程实例、任务状态等信息,方便监控和管理工作流程执行情况。
### 1.3 Activiti 在实际项目中的应用场景
- 请假审批流程:员工提交请假申请后,需要经过一系列的审批步骤,包括主管审核、部门经理审批等,最终确定是否批准。
- 采购流程:从采购申请到订单审批,再到供应商选择和物流配送,Activiti 可以协助优化和管理采购流程,提高效率和准确性。
- 人力资源流程:包括员工入职、转正、离职等流程,Activiti 可以自动化处理各种人力资源流程,减少繁琐的人工操作。
- 审批流程:例如合同审批、财务审批等,Activiti 可以规范审批流程,提高审批效率和准确性。
希望这一章节对您了解 Activiti 的简介与概述有所帮助。接下来,我们将继续探讨 Activiti 环境搭建与配置。
# 2. 环境搭建与准备工作
### 2.1 准备 Java 开发环境
在进行 Activiti 工作流引擎的环境搭建前,首先要确保已经正确搭建了 Java 的开发环境。如果你尚未安装 Java 开发环境,可以按照以下步骤来进行安装:
```java
// 示例代码,安装 Java 开发环境的命令示意
sudo apt-get update
sudo apt-get install default-jdk
```
### 2.2 下载并配置 Activiti 工作流引擎
接下来,我们需要下载并配置 Activiti 工作流引擎,可以按照以下步骤进行操作:
```java
// 示例代码,下载并解压 Activiti 工作流引擎
wget https://www.activiti.org/download
tar -zxvf activiti-7.1.39.zip
```
### 2.3 配置数据库,部署 Activiti 相关表结构
在正式使用 Activiti 工作流引擎之前,我们还需要配置数据库,并将 Activiti 相关的表结构部署至数据库中。以下是一个简单的示例:
```java
// 示例代码,使用 MySQL 数据库并创建 Activiti 相关表结构
CREATE DATABASE activiti;
USE activiti;
SOURCE /path/to/activiti/database/create/activiti.mysql.create.engine.sql;
```
以上是环境搭建与准备工作的基本步骤,在接下来的章节中,我们将会继续进行 Activiti 环境搭建与配置的详细讲解。
# 3. Activiti 环境搭建与配置
在上一章节中,我们已经完成了环境的准备工作,接下来将进行 Activiti 环境的搭建与配置。
#### 3.1 创建 Activiti 项目
首先,我们需要创建一个 Maven 项目作为 Activiti 的开发环境。在你的 IDE 中选择 Maven 项目,并添加以下依赖:
```xml
<dependency>
<groupId>org.activiti</groupId>
<artifactId>activiti-engine</artifactId>
<version>5.22.0</version>
</dependency>
<dependency>
<groupId>org.activiti</groupId>
<artifactId>activiti-spring</artifactId>
<version>5.22.0</version>
</dependency>
```
#### 3.2 配置 Activiti 运行环境
在项目的 src/main/resources 目录下创建 activiti.cfg.xml 配置文件,配置数据库连接等相关信息:
```xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
<bean id="processEngineConfiguration" class="org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration">
<property name="jdbcUrl" value="jdbc:mysql://localhost:3306/activiti"/>
<property name="jdbcDriver" value="com.mysql.jdbc.Driver"/>
<property name="jdbcUsername" value="root"/>
<property name="jdbcPassword" value="password"/>
<property name="databaseSchemaUpdate" value="true"/>
</bean>
<bean id="processEngine" class="org.activiti.engine.ProcessEngines" factory-method="getDefaultProcessEngine"/>
</beans>
```
#### 3.3 运行 Activiti 工作流引擎并验证环境搭建成功
在项目中编写一个简单的启动类,加载 Spring 容器并验证 Activiti 环境是否搭建成功:
```java
import org.activiti.engine.ProcessEngine;
import org.activiti.engine.ProcessEngines;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class ActivitiStarter {
public static void main(String[] args) {
ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("activiti.cfg.xml");
ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
if (processEngine != null) {
System.out.println("Activiti 工作流引擎启动成功!");
} else {
System.out.println("Activiti 工作流引擎启动失败!");
}
}
}
```
运行 ActivitiStarter 类,如果控制台打印出 "Activiti 工作流引擎启动成功!",则代表环境搭建成功。
以上就是 Activiti 环境搭建与配置的内容,接下来我们将会创建第一个工作流程。
# 4. 创建第一个工作流程
### 4.1 定义工作流程的需求与流程图
我们首先需要明确工作流程的需求,确定工作流程中涉及的流程步骤和角色。在本章中,我们将创建一个简单的请假审批工作流程作为示例。
以下是我们的流程图:
```mermaid
graph TD
A(开始)-->B(填写请假申请)
B-->C(部门经理审批)
C-->D(HR审批)
D-->E(结束)
```
### 4.2 使用 Activiti Designer 创建工作流程
1. 打开 Activiti Designer 工具。
2. 在工具中新建一个项目,选择合适的项目类型和路径。
3. 在项目中创建一个新的工作流程文件(.bpmn文件)。
4. 在工作流程设计器中,根据需求画出流程图。
5. 在流程图中添加用户任务、网关等元素,并设置相应的属性。
6. 保存工作流程文件。
以下是我们的示例工作流程图:
### 4.3 部署并启动第一个工作流程
1. 打开 Activiti Explorer 控制台。
2. 在控制台中选择要部署的工作流程文件。
3. 部署工作流程文件到 Activiti 引擎中。
4. 在控制台中启动第一个工作流程实例。
注意:在每个步骤中,需要根据实际情况进行适当的配置和设置。以上步骤仅为演示示例。
至此,我们已经成功创建并启动了一个简单的工作流程。在接下来的章节中,我们将学习如何查看和处理工作流程中的任务。
# 5. 工作流程实例与任务处理
### 5.1 查看工作流程实例及其状态
在 Activiti 中,我们可以通过以下方式来查看工作流程实例及其状态:
```java
// 获取工作流引擎
ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
// 获取运行时服务
RuntimeService runtimeService = processEngine.getRuntimeService();
// 根据流程定义的 Key 查询所有工作流实例
List<ProcessInstance> processInstances = runtimeService.createProcessInstanceQuery()
.processDefinitionKey("workflow1")
.list();
// 遍历工作流实例并输出相关信息
for (ProcessInstance processInstance : processInstances) {
System.out.println("流程实例ID:" + processInstance.getId());
System.out.println("流程定义ID:" + processInstance.getProcessDefinitionId());
System.out.println("流程实例状态:" + processInstance.isEnded());
System.out.println("当前活动任务:" + processInstance.getActivityId());
}
```
**代码解释:**
首先,我们需要获取 Activiti 的工作流引擎对象 `ProcessEngine`,通过其中的 `getDefaultProcessEngine()` 方法可以获取默认的工作流引擎实例。
接下来,我们使用工作流引擎的 `getRuntimeService()` 方法获取运行时服务对象 `RuntimeService`,该服务提供了许多操作工作流实例和任务的方法。
然后,我们通过 `createProcessInstanceQuery()` 方法创建一个工作流实例查询对象,并通过 `processDefinitionKey()` 方法指定流程定义的 Key 来查询相关的工作流实例。
最后,我们遍历返回的工作流实例列表,输出每个工作流实例的 ID、流程定义 ID、结束状态和当前活动任务。
### 5.2 处理工作流程中的任务
在 Activiti 中,我们可以通过以下方式来处理工作流程中的任务:
```java
// 获取工作流引擎
ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
// 获取任务服务
TaskService taskService = processEngine.getTaskService();
// 根据任务的候选人查询待办任务列表
List<Task> tasks = taskService.createTaskQuery()
.taskCandidateUser("user1")
.list();
// 遍历待办任务并输出相关信息
for (Task task : tasks) {
System.out.println("任务ID:" + task.getId());
System.out.println("任务名称:" + task.getName());
System.out.println("任务的创建时间:" + task.getCreateTime());
System.out.println("任务的候选人:" + task.getAssignee());
}
// 完成任务
taskService.complete(task.getId());
```
**代码解释:**
首先,我们需要获取 Activiti 的工作流引擎对象 `ProcessEngine`,通过其中的 `getDefaultProcessEngine()` 方法可以获取默认的工作流引擎实例。
接下来,我们使用工作流引擎的 `getTaskService()` 方法获取任务服务对象 `TaskService`,该服务提供了许多操作工作流任务的方法。
然后,我们通过 `createTaskQuery()` 方法创建一个任务查询对象,并通过 `taskCandidateUser()` 方法指定任务的候选人来查询待办任务列表。
最后,我们遍历返回的待办任务列表,输出每个任务的 ID、名称、创建时间和候选人,并通过 `complete()` 方法完成该任务。
### 5.3 任务的审批与流转
在 Activiti 中,我们可以通过以下方式来进行任务的审批与流转:
```java
// 获取工作流引擎
ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
// 获取任务服务
TaskService taskService = processEngine.getTaskService();
// 获取当前登录用户的任务列表
List<Task> tasks = taskService.createTaskQuery()
.taskAssignee("user1")
.list();
// 遍历任务列表并输出相关信息
for (Task task : tasks) {
System.out.println("任务ID:" + task.getId());
System.out.println("任务名称:" + task.getName());
System.out.println("任务的处理人:" + task.getAssignee());
System.out.println("任务的创建时间:" + task.getCreateTime());
System.out.println("任务的到期时间:" + task.getDueDate());
}
// 审批任务
for (Task task : tasks) {
if ("审批通过".equals(task.getName())) {
taskService.complete(task.getId(), Collections.singletonMap("approval", "approved"));
} else if ("审批拒绝".equals(task.getName())) {
taskService.complete(task.getId(), Collections.singletonMap("approval", "rejected"));
}
}
```
**代码解释:**
首先,我们需要获取 Activiti 的工作流引擎对象 `ProcessEngine`,通过其中的 `getDefaultProcessEngine()` 方法可以获取默认的工作流引擎实例。
接下来,我们使用工作流引擎的 `getTaskService()` 方法获取任务服务对象 `TaskService`,该服务提供了许多操作工作流任务的方法。
然后,我们通过 `createTaskQuery()` 方法创建一个任务查询对象,并通过 `taskAssignee()` 方法指定任务的处理人查询当前登录用户的任务列表。
最后,我们遍历返回的任务列表,输出每个任务的 ID、名称、处理人、创建时间和到期时间,并通过 `complete()` 方法完成审批通过或审批拒绝的任务,并提供相应的审批结果。
# 6. 工作流程的监控与优化
随着工作流程的运行,对其执行情况进行监控是非常重要的。同时,针对监控结果进行优化也是提高工作流程效率的关键步骤。
#### 6.1 监控工作流程执行情况
在 Activiti 中,可以通过查询历史数据来监控工作流程的执行情况。通过以下代码可以实现历史数据的查询:
```java
HistoryService historyService = processEngine.getHistoryService();
// 查询流程实例的历史数据
List<HistoricProcessInstance> historicProcessInstances = historyService.createHistoricProcessInstanceQuery()
.processDefinitionKey("yourProcessDefinitionKey")
.list();
// 查询某个流程实例的历史任务数据
List<HistoricTaskInstance> historicTaskInstances = historyService.createHistoricTaskInstanceQuery()
.processInstanceId("yourProcessInstanceId")
.list();
```
上述代码中,通过 HistoryService 可以获取历史数据查询的实例,然后可以通过相应的查询条件获取需要的历史数据,进行监控和分析。
#### 6.2 对工作流程性能进行优化
工作流程的性能优化主要包括流程模型的优化、流程图的简化、以及相关代码的优化等方面。对于流程模型的优化,可以通过 Activiti 提供的设计器进行流程图的重新设计,去除不必要的环节,简化流程逻辑。同时,通过代码的优化,可以提高工作流引擎的执行效率。例如,合理使用缓存、优化查询语句等手段来提升性能。
#### 6.3 实施工作流程版本升级与迁移
随着业务的发展,工作流程可能需要进行版本升级或迁移。在 Activiti 中,可以通过使用版本管理功能来对工作流程进行版本控制和升级。同时,通过对历史数据的迁移,可以保证新老版本数据的兼容性,确保业务的连续性和稳定性。
希望以上内容能帮助您更好地监控和优化工作流程,提升工作效率。
0
0