公司项目组在考虑工作流,首选了activiti,首先我们要明确为什么要使用activiti,有什么好处。
在工作中有些项目会用到工作流,如果简单的项目,我们就无需使用类似activiti、jbpm等工作流框架。因为原本项目就简单,几个简单的流程,我们完全可以自己去写逻辑实现功能。但当如果有复杂的工作流程,而且流程极容易发生变化,相信每个程序员都很烦业务逻辑发生改变,抱怨为什么当初说好了,现在又变。没办法,我们的客户就是这么善变,而且客户是上帝,我们的衣食父母。而引入了activiti等类似的流程框架引擎后,我们就不用再去关心流程的维护,只关心我们的逻辑即可。
在这里总结一下,如果项目简单,流程不会频繁的发生变化,那么我们就可以自己写流程,完成基本功能,如果流程复杂,而且极容易发生变化,那么我们就应该考虑引入现成的流程框架引擎了。
下面我们开始我们的activiti之旅吧。
第一步,如果我们想使用activiti,那么肯定离不开jar,java就是离不开jar。我们需要jar里面的接口完成我们所需要的功能,而jar又做了什么操作呢,当然是对数据库进行基本的读写操作了。activiti支持很多数据库的。
第二步,activiti流程定义,使用了BPMN2.0标准(最终就是一个xml)。而且activiti提供了流程建模工具。但是activiti的建模工具对eclipse的版本有要求,官网明确的写着(If you would like to use the Activiti Designer then you need Eclipse Kepler or Luna),所以我们需要下载Kepler或者Luna版本。其他版本是无法使用activiti designer插件的。下面是两个版本的官网地址:
https://www.eclipse.org/kepler/
下载完后可以安装activiti designer插件了。
开始创建数据库吧,首先我们使用测试的方式创建数据库
activiti需要spring的支持,spring帮助activiti创建了很多activiti需要使用的bean。
如果连接数据库,那肯定是需要数据源的,创建一个文件名为activiti.cfg.xml的配置文件,里面定义一个数据源,然后定义一个流程引擎配置bean。下面是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" xmlns:p="http://www.springframework.org/schema/p" xmlns:context="http://www.springframework.org/schema/context" xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:aop="http://www.springframework.org/schema/aop" 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/context http://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd"> <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> <property name="driverClassName" value="com.mysql.jdbc.Driver" /> <property name="url" value="jdbc:mysql://localhost:3306/newlife" /> <property name="username" value="root" /> <property name="password" value="root" /> </bean> <bean id="processEngineConfiguration" class="org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration"> <!-- 数据源 --> <property name="dataSource" ref="dataSource" /> <!-- activiti数据库表处理策略 --> <property name="databaseSchemaUpdate" value="true"/> </bean> </beans>
可以看到上面的约束都是spring的,在这里注意了,数据库是很早之前安装的,所以是mysql 5.5.5版本,而最新版的jdbc连接驱动更改了名 com.mysql.cj.jdbc.Driver 是用来连接mysql 6.x.x版本的,所以我下载了一个之前版本的jdbc驱动包
我这里数据库名称为newlife,所以要注意在mysql中新建一个这个数据库
下面我们来执行以下流程引擎,它就会为我们自动创建activiti所需要的所有表
1 @Test 2 public void createDB() throws SQLException, ClassNotFoundException{ 3 String resource="activiti.cfg.xml"; 4 ProcessEngineConfiguration configuration=ProcessEngineConfiguration.createProcessEngineConfigurationFromResource(resource); 5 ProcessEngine engine=configuration.buildProcessEngine(); 6 }
我们看一下数据库,是不是多了很多的表呢
下面我们来说一下基本的表结构用处
所有的表都以act开头,当然应该是activit的简写。中间re的为repository,代表资源文件。ru的为runtime,这是运行时表,包含流程实例,任务,变量,异步任务等。这些表只保存流程中的数据,当流程结束,这些数据会进行删除操作,这样保持了这些表中的数据最小化,提高效率。id表示identity,表示身份信息,比如用户,组等。
hi历史表,流程中的数据会移动到这些表中,也就是保存历史流程。ge表示general,表示通用数据。
今天的记录就到这里,接下来会结合流程的部署、发布流程实例查看数据库中的数据,以了解数据库中的字段都代表什么意思。