官方在线用户手册(英文版):http://activiti.org/userguide/index.html
中文用户手册:http://www.mossle.com/docs/activiti/index.html
前言:目前在学习使用 Activiti,将学习过程中较重要的知识点或者遇到的问题与解决方案 记录下来,方便后来者学习与查询。
一、项目框架介绍
所有的测试都是依据在一定的环境框架上的。为了需要而测试。
我这里选用的是 Spring + SpringMVC + Maven + mysql
在项目中引入 Activiti,在pom 中添加,version 写实际版本(5.21.0)
二、数据库
不管什么项目,数据库肯定是少不了的啦。
下面列出Activiti使用的数据库类型(大小写敏感)。
Activiti数据库类型 | JDBC URL实例 | 备注 |
h2 | jdbc:h2:tcp://localhost/activiti | 默认配置的数据库 |
mysql | jdbc:mysql://localhost:3306/activiti?autoReconnect=true | 使用mysql-connector-java驱动测试 |
oracle | jdbc:oracle:thin:@localhost:1521:xe | |
postgres | jdbc:postgresql://localhost:5432/activiti | |
db2 | jdbc:db2://localhost:50000/activiti | |
mssql | jdbc:sqlserver://localhost:1433/activiti | |
ACT_开头。 第二部分是表示表的用途的两个字母标识。 用途也和服务的API对应。
- ACT_RE_*: 'RE'表示
repository
。 这个前缀的表包含了流程定义和流程静态资源 (图片,规则,等等)。 - ACT_RU_*: 'RU'表示
runtime
。 这些运行时的表,包含流程实例,任务,变量,异步任务,等运行中的数据。 Activiti只在流程实例执行过程中保存这些数据, 在流程结束时就会删除这些记录。 这样运行时表可以一直很小速度很快。 - ACT_ID_*: 'ID'表示
identity
。 这些表包含身份信息,比如用户,组等等。 - ACT_HI_*: 'HI'表示
history
。 这些表包含历史数据,比如历史流程实例, 变量,任务等等。 - ACT_GE_*:
通用
数据, 用于不同场景下。
数据库脚本 是在 activiti-engine的jar 中(activiti-engine-x.jar), 在org/activiti/db/create包下(drop目录里是删除语句)
执行 DbSchemaCreate 类的main方法
正确配置Activiti的项目,启动的时候,如果事先数据库中不存在表的话,可以自动将对应版本的数据库表创建在数据库中。
三、日志
在Activiti 5.12 开始,slf4j 作为日志框架。所有日志(activiti, spring, mybatis等等)都转发给SLF4J 允许使用你选择的日志实现。
默认activiti-engine依赖中没有提供SLF4J绑定的jar, 需要根据你的实际需要使用日志框架。(如果不加也不会有任何提示,不会记录日志而已)
常用的maven的pom配置为
未完待续(……)
作者:panie