流程引擎activiti的使用心得

最近在开发流程相关的项目,因此使用了行业中比较成熟的流程引擎activiti。

自己的英文水平有限,因此找了一个具有中文文档的版本5.16.0。

activiti相关的文档呢,我就不赘述了,直接看文档:http://www.mossle.com/docs/activiti/index.html


只在此记录下开发过程中遇到的问题及相关的一些经验,和大家一起讨论分享。

一、activiti数据库

activiti5.16中会使用到他自己创建的24张表,以前都是我们自己手动创建的,其实可以修改配置文件进行自动创建。

    
        
        
        
        true" />
        
    
只有把上面的databaseSchemaUpdate设置成true就不用手动创建24张表了。

二、业务数据

一般来说自己的项目都会有自己的业务,因此我们会创建自己的业务数据库用于存储自己的业务,其实activiti完全可以把我们的业务数据序列化保存到他的数据库中,

可以通过activiti提供的taskService,historySevice等接口查询我们的业务数据,因此如果只是简单的要求,完全可以不用创建自己的业务数据库。

但我们的项目要求要进行一些业务相关的查询和统计,其实大多数项目都会有这种要求,因此我还是建议创建自己的业务数据库。

在创建自己的业务数据库时,为了以后查询的方便和效率,建议把流程相关的数据(比如task的创建、领取、结束时间等等)可以同步到自己的业务数据库,这样到

时统计时间相关的数据时,就不会存在着跨数据库查询,方便些同时效率也会高些。

由于我们使用的数据库是postgresql,其实还可以将activiti的数据库和业务数据库放到同一数据库的不同的schema下,这样方便万一要使用跨表查询时,使用schema

通信会比较方便。

三、流程监听

activiti的监听功能其实很强大的,我们的项目中的业务逻辑都可以写到监听中。在流程图bpmn中节点添加监听,在listener中去存储业务数据。

流程引擎activiti的使用心得_第1张图片

四、单元测试

由于领取任务时都需要手动填写userId以及taskId,给我们的测试造成很大的不方便,因此我们可以通过taskSevice查询出相关的数据,然后自动设置,实现自己测试。

	/**
	 * 
	 * 描述	获取taskId以及userId
	 *
	 */
	protected void getTaskInfo(){
		//目前都只有一个任务
		Task task = taskService.createTaskQuery().processInstanceId(processInstanceId).list().get(0);
		//必须有值,都取第一个
		IdentityLink identityLink = taskService.getIdentityLinksForTask(task.getId()).get(0);
		
		taskid = task.getId();
		userid = identityLink.getUserId();
	}
五、异常处理

使用spring4中的ControllerAdvice来进行统一的异常处理

@ControllerAdvice
public class xxxHandler {

	private static final Logger LOGGER = Logger.getLogger(xxxHandler.class);
	
	@ExceptionHandler(ActivitiException.class)
	public String xxxHandler(ActivitiException exception){
		logger("xxx", exception);
		return JsonUtil.toJson("xxx");
	}
	
	@ExceptionHandler(RuntimeException.class)
	public String xxxHandler(RuntimeException exception){
		logger("xxx", exception);
		return JsonUtil.toJson("xxx");
	}
	
	private void logger(String msg,Exception e){
		LOGGER.error(TimeUtil.getNow()+msg);
		LOGGER.error(e.getMessage(), e);
	}
}

六、日志记录

我们需要把项目抛出异常时记录下相关的日志,方便我们后期运维,因此使用AOP对此进行记录日志。


项目还没有做完,后面会更新。

你可能感兴趣的:(web)