Activiti7原生整合和工作流相关概念详解

一、概述

Activiti是一个工作流引擎, Activiti可以将业务系统中复杂的业务流程抽取出来,并用专门的建模语言BPMN2.0进行定义,业务流程按照预先定义的流程进行执行,实现了系统的流程由Activiti进行管理,减少业务系统由于流程变更进行系统升级改造的工作量,提高了系统的健壮性,减少了系统开发维护成本。

官网地址:

<https://www.activiti.org/>

二、基于Maven整合Activiti

这也是较为原生的方式去使用Activiti,有助于对Activiti基础的理解。

2.1 创建一个Maven工程

在这里插入图片描述
在这里插入图片描述

输入完项目基本信息后,点击下方的Finish即可创建一个最基本的Maven项目。

2.2 在pom文件中添加Maven坐标

<properties>
    <slf4j.version>1.6.6</slf4j.version>
    <log4j.version>1.2.12</log4j.version>
    <activiti.version>7.0.0.Beta1</activiti.version>
</properties>
<dependencies>
    <!-- activiti流程引擎 -->
    <dependency>
        <groupId>org.activiti</groupId>
        <artifactId>activiti-engine</artifactId>
        <version>${activiti.version}</version>
    </dependency>
    <!-- activiti和spring的整合包 -->
    <dependency>
        <groupId>org.activiti</groupId>
        <artifactId>activiti-spring</artifactId>
        <version>${activiti.version}</version>
    </dependency>
    <!-- bpmn 模型处理 -->
    <dependency>
        <groupId>org.activiti</groupId>
        <artifactId>activiti-bpmn-model</artifactId>
        <version>${activiti.version}</version>
    </dependency>
    <!-- bpmn 转换 -->
    <dependency>
        <groupId>org.activiti</groupId>
        <artifactId>activiti-bpmn-converter</artifactId>
        <version>${activiti.version}</version>
    </dependency>
    <!-- bpmn json数据转换 -->
    <dependency>
        <groupId>org.activiti</groupId>
        <artifactId>activiti-json-converter</artifactId>
        <version>${activiti.version}</version>
    </dependency>
    <!-- bpmn 布局 -->
    <dependency>
        <groupId>org.activiti</groupId>
        <artifactId>activiti-bpmn-layout</artifactId>
        <version>${activiti.version}</version>
    </dependency>
    <!-- activiti 云支持 -->
    <dependency>
        <groupId>org.activiti.cloud</groupId>
        <artifactId>activiti-cloud-services-api</artifactId>
        <version>${activiti.version}</version>
    </dependency>
    <!-- mysql驱动(版本不要过低,要不然连接mysql8 的时候直接会报如下错误:) -->
    <!-- Cannot create PoolableConnectionFactory (Unknown system variable ‘query_cache_size‘) -->
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>5.1.47</version>
    </dependency>
    <!-- mybatis -->
    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis</artifactId>
        <version>3.4.5</version>
    </dependency>
    <!-- 链接池 -->
    <dependency>
        <groupId>commons-dbcp</groupId>
        <artifactId>commons-dbcp</artifactId>
        <version>1.4</version>
    </dependency>
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.12</version>
    </dependency>
    <!-- log start -->
    <dependency>
        <groupId>log4j</groupId>
        <artifactId>log4j</artifactId>
        <version>${log4j.version}</version>
    </dependency>
    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-api</artifactId>
        <version>${slf4j.version}</version>
    </dependency>
    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-log4j12</artifactId>
        <version>${slf4j.version}</version>
    </dependency>
</dependencies>

如果报 com.github.jgraph:jgraphx 依赖找不到,有两种解决方案:

  • 可以手动将依赖下载到本地

  • 如果不想看到报红可以将该依赖排除

    <dependency>
        <groupId>org.activiti</groupId>
        <artifactId>activiti-bpmn-layout</artifactId>
        <version>${activiti.version}</version>
        <exclusions>
            <exclusion>
                <groupId>com.github.jgraph</groupId>
                <artifactId>jgraphx</artifactId>
            </exclusion>
        </exclusions>
    </dependency>
    

    因为其实没有该依赖也不影响使用

2.3 添加log4j日志配置文件

因为引入了log4jMaven坐标,所以需要在项目的resources目录下,增加log4j.properties配置文件。

这样系统就会根据配置文件中的配置去输出日志了。

# Set root category priority to INFO and its only appender to CONSOLE.
#log4j.rootCategory=INFO, CONSOLE debug info warn error fatal
log4j.rootCategory=debug, CONSOLE, LOGFILE
# Set the enterprise logger category to FATAL and its only appender to CONSOLE.
log4j.logger.org.apache.axis.enterprise=FATAL, CONSOLE
# CONSOLE is set to be a ConsoleAppender using a PatternLayout.
log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
log4j.appender.CONSOLE.layout.ConversionPattern=%d{ISO8601} %-6r[%15.15t] %-5p %30.30c %x - %m\n
# LOGFILE is set to be a File appender using a PatternLayout.
log4j.appender.LOGFILE=org.apache.log4j.FileAppender
log4j.appender.LOGFILE.File=F:\activiti\activiti.log
log4j.appender.LOGFILE.Append=true
log4j.appender.LOGFILE.layout=org.apache.log4j.PatternLayout
log4j.appender.LOGFILE.layout.ConversionPattern=%d{ISO8601} %-6r[%15.15t] %-5p %30.30c %x - %m\n

可以根据项目需求或者个人喜好进行更改。

注意:

log4j.appender.LOGFILE.File配置的值F:\activiti\activiti.logF盘的对应路径下,activiti.log文件需要提前存在,要不然会报文件找不到的异常。

2.4 添加Activiti配置文件

Activiti提供的默认方式来创建MySQL表的要求是在resources下创建activiti.cfg.xml文件.

默认方式配置要求:

  • 目录和文件名不能修改,因为Activiti的源码中已经编写了到固定的目录读取固定文件名的文件。
  • activiti.cfg.xmlbean的名字叫processEngineConfiguration,不要修改这个名称。
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans
                    http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/contex
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx.xsd">
    
    <!-- 这里可以使用 dbcp 连接池 -->
    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
        <property name="driverClassName" value="com.mysql.jdbc.Driver" />
        <property name="url" value="jdbc:mysql:///activiti" />
        <property name="username" value="root" />
        <property name="password" value="123456" />
        <property name="maxActive" value="3" />
        <property name="maxIdle" value="1" />
    </bean>

    <bean id="processEngineConfiguration"
          class="org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration">
        <!-- 引用数据源 上面已经设置好了-->
        <property name="dataSource" ref="dataSource" />
        <!-- activiti数据库表处理策略 -->
        <property name="databaseSchemaUpdate" value="true"/>
    </bean>
    
</beans>

三、生成Activiti中的25张表

3.1 使用默认方式

就是使用默认的配置文件(配置文件名称和位置不能修改)和流畅引擎类(bean名称不能修改)的方式。

public class TestActiviti {

    @Test
    public void testCreateDbTable() {
        // 使用classpath下的activiti.cfg.xml中的配置创建processEngine
        // 而resources下的文件就是处于classpath下的
		ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
		System.out.println(processEngine);
    }
}

3.2 使用自定义方式

配置文件的名字可以自定义,bean的名字也可以自定义。

但是下面的代码中还是写的和原来默认一样的配置文件名和bean。

public class TestActiviti {

    @Test
    public void testCreateDbTable() {
        ProcessEngineConfiguration processEngineConfiguration = ProcessEngineConfiguration.
                createProcessEngineConfigurationFromResource("activiti.cfg.xml", "processEngineConfiguration");
		// 获取流程引擎对象(此时就会创建数据库)
        ProcessEngine processEngine = processEngineConfiguration.buildProcessEngine();
    }
}

四、表结构解析

执行上面代码后就会在本地的activiti数据库中创建25张表。
在这里插入图片描述

4.1 表命名规则说明

  • ACTACT其实也就是Activiti 的意思,就是说这些表都是Activiti相关的表。

  • ACT_RERE表示 repository。 这个前缀的表包含了流程定义和流程静态资源 (图片,规则,等等)。

  • ACT_RURU表示 runtime。 这些运行时的表,包含流程实例,任务,变量,异步任务,等运行中的数据。

    Activiti 只在流程实例执行过程中保存这些数据, 在流程结束时就会删除这些记录。

    ​ 这样运行时表可以一直很小速度很快。

  • ACT_HIHI表示 history。 这些表包含历史数据,比如历史流程实例, 变量,任务等等。

  • ACT_GEGE 表示general。 通用数据, 用于不同场景下

4.2 Activiti数据表说明

表分类表名解释
一般数据
[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_RE_DEPLOYMENT]部署单元信息
[ACT_RE_MODEL]模型信息
[ACT_RE_PROCDEF]已部署的流程定义
运行实例表
[ACT_RU_EVENT_SUBSCR]运行时事件
[ACT_RU_EXECUTION]运行时流程执行实例
[ACT_RU_IDENTITYLINK]运行时用户关系信息,存储任务节点与参与者的相关信息
[ACT_RU_JOB]运行时作业
[ACT_RU_TASK]运行时任务
[ACT_RU_VARIABLE]运行时变量表

五、Activiti的基本类关系

Activiti7中,已经删除了IdentityServiceFormService两个Serivce类。
在这里插入图片描述
activiti.cfg.xmlActiviti的引擎配置文件。

包括ProcessEngineConfiguration的定义、数据源定义、事务管理器等。相当于一个Spring配置文件。

ProcessEngineConfiguration可以用来创建ProceccEngine

ProceccEngine又可以获取管理Activiti中各种核心Service

5.1 ProcessEngineConfiguration

流程引擎的配置类(ProcessEngineConfiguration),通过ProcessEngineConfiguration可以创建工作流引擎ProceccEngine

创建processEngineConfiguration也有两种方式:

  • 方式一:固定名称

    下边的代码要求activiti.cfg.xml中必须有一个processEngineConfigurationbean

    ProcessEngineConfiguration configuration = ProcessEngineConfiguration.createProcessEngineConfigurationFromResource("activiti.cfg.xml")
    
  • 方式一:自定义名称

    activiti.cfg.xml配置文件名称可更改,processEngineConfigurationbean名称可更改。

    ProcessEngineConfiguration.createProcessEngineConfigurationFromResource(String resource, String beanName);
    

5.2 ProcessEngineConfiguration

工作流引擎(ProcessEngine),相当于一个统一管理接口。

通过ProcessEngineConfiguration创建processEngine,通过ProcessEngine获取各个Service接口。

  • 方式一:固定名称

    下边的代码要求activiti.cfg.xml中必须有一个processEngineConfigurationbean

    // 直接使用工具类 ProcessEngines,使用classpath下的activiti.cfg.xml中的配置创建processEngine
    ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
    System.out.println(processEngine);
    
  • 方式一:自定义名称

    activiti.cfg.xml配置文件名称可更改,processEngineConfigurationbean名称可更改。

    //先构建ProcessEngineConfiguration
    ProcessEngineConfiguration configuration = ProcessEngineConfiguration.createProcessEngineConfigurationFromResource("activiti.cfg.xml");
    //通过ProcessEngineConfiguration创建ProcessEngine,此时会创建数据库
    ProcessEngine processEngine = configuration.buildProcessEngine();
    

5.3 Servcie服务接口

各类Service服务接口是工作流引擎提供用于进行工作流部署、执行、管理的服务接口。

使用这些接口可以就是操作服务对应的数据表。

1)service概览
service名称service作用
RepositoryServiceactiviti的资源管理类
RuntimeServiceactiviti的流程运行管理类
TaskServiceactiviti的任务管理类
HistoryServiceactiviti的历史管理类
ManagerServiceactiviti的引擎管理类
  • RepositoryService

    Activiti的资源管理类,提供了管理和控制流程发布包和流程定义的操作。

    使用工作流建模工具设计的业务流程图需要使用此service将流程定义文件的内容部署到计算机。

    除了部署流程定义以外还可以查询引擎中的发布包和流程定义,暂停或激活发布包,对应全部和特定流程定义。

    暂停意味着它们不能再执行任何操作了,激活是对应的反向操作。获得多种资源,像是包含在发布包里的文件, 或引擎自动生成的流程图。

    获得流程定义的pojo版本, 可以用来通过Java解析流程,而不必通过xml

  • RuntimeService

    Activiti的流程运行管理类。可以从这个服务类中获取很多关于流程执行相关的信息

  • TaskService

    Activiti的任务管理类。可以从这个类中获取任务的信息。

  • HistoryService

    Activiti的历史管理类,可以查询历史信息,执行流程时,引擎会保存很多数据(根据配置),比如流程实例启动时间,任务的参与者, 完成任务的时间,每个流程实例的执行路径,等等。 这个服务主要通过查询功能来获得这些数据。

  • ManagementService

    Activiti的引擎管理类,提供了对 Activiti 流程引擎的管理和维护功能,这些功能不在工作流驱动的应用程序中使用,主要用于 Activiti系统的日常维护。

2)Service创建方式

通常通过ProcessEngine创建各类Service,就以RuntimeService为例,其余Service也是一样的。

RuntimeService runtimeService = processEngine.getRuntimeService();
RepositoryService repositoryService = processEngine.getRepositoryService();
TaskService taskService = processEngine.getTaskService();

ce**

Activiti的引擎管理类,提供了对 Activiti 流程引擎的管理和维护功能,这些功能不在工作流驱动的应用程序中使用,主要用于 Activiti系统的日常维护。

2)Service创建方式

通常通过ProcessEngine创建各类Service,就以RuntimeService为例,其余Service也是一样的。

RuntimeService runtimeService = processEngine.getRuntimeService();
RepositoryService repositoryService = processEngine.getRepositoryService();
TaskService taskService = processEngine.getTaskService();
  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
工作流引擎Activiti是一个开源的、基于Java开发工作流引擎。它通过定义、执行和管理工作流程,实现业务流程的自动化。 Activiti结构主要包括以下几个: 1. ACT_RE_*:存储流程定义和其相关静态信息,如流程定义、流程定义属性等。 2. ACT_RU_*:运行时的,存储流程实例、任务、事件等运行时数据。 3. ACT_ID_*:存储身份认证相关,如用户、组、角色等。 4. ACT_HI_*:历史数据,存储流程实例、任务实例、变量、任务参数、作业、身份认证相关的历史数据。 5. ACT_GE_*:通用数据,存储通用的数据,如数据源配置、引擎属性等。 代码方面,使用Activiti可以通过以下步骤实现工作流的定义和执行: 1. 引入Activiti相关依赖。 2. 配置数据库连接信息、引擎属性等。 3. 创建流程定义文件,使用BPMN 2.0规范定义流程。 4. 使用Java代码部署流程定义文件,将流程定义文件部署到工作流引擎中。 5. 创建流程实例,通过调用工作流引擎的API启动一个流程实例。 6. 处理任务,根据流程定义中定义的任务节点,执行相关的操作。 7. 完成任务,通过调用工作流引擎的API完成当前的任务。 8. 监听流程事件,根据需要可以注册一些监听器来监听流程的执行情况。 9. 查询历史数据,可以通过API查询历史流程实例、任务实例、变量等历史数据。 总之,工作流引擎Activiti结构对于工作流的定义和执行非常重要,而相应的代码则通过API的调用实现了工作流程的定义、部署、执行和监控等功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值