activiti processEngineLifecycleListener使用
1.1.1. 前言
实际开发中,有需求如下:
第一:项目启动部署的时候,我们需要监控activiti 工作流引擎是否真正的已经实例化启动了,这里说的是工作流引擎的启动,不是流程实例的启动,对此要特别说明一下。因为我们这里说的工作流引擎具体指的是ProcessEngine接口中的子类ProcessEngineImpl是否实例化,如果这个对象在项目启动的时候,没有被实例化,那肯定工作流引擎是用不成了,因为所有的xxxService肯定都没有。所有项目启动的时候监控这个对象还是很有必要的。
第二:项目停止的时候,也就是项目终止的时候,我们也要去销毁这个ProcessEngineImpl这个对象,不销毁这个对象,肯定容易引起内存泄露。
上面的两个问题,我们如何去实现呢?这就是本章我们要详细讲解的processEngineLifecycleListener的使用。
1.1.2. 配置
activiti 工作流引擎所以的配置信息都是在org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration,这个对象中配置的,当然了与spring集成的时候,就在spring配置对象中配置,配置信息如下:
1.1.2.1. 第一种方式
xml直接配置的方式,具体的配置信息如下:
<bean id="processEngineConfiguration" class="org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration"> <property name="processEngineLifecycleListener" ref="myProcessEngineLifecycleListener"/> </bean>
1.1.2.2. 第二种方式
第二种方式是动态属性的配置方式,设置的属性信息如下:
@Override
public void beforeInit(
ProcessEngineConfigurationImpl processEngineConfiguration) {
DataSource dataSource = JdbcUtils.getReadDataSource();
processEngineConfiguration.setDataSource(dataSource);
processEngineConfiguration.setHistoryLevel(HistoryLevel.FULL);
processEngineConfiguration.setDbIdentityUsed(false);
//databaseSchemaUpdate
//processEngineConfiguration.setDatabaseSchemaUpdate("true");
processEngineConfiguration.setProcessEngineLifecycleListener(myProcessEngineConfigurator);
}
对于这种方式有疑问或者不会的可以参考: activiti 动态配置 activiti 监听引擎启动和初始化(高级源码篇)http://blog.csdn.net/qq_30739519/article/details/51170011
上面的两种方式,主要都是配置信息,那如何定义配置信息中的具体类呢?
1.1.2.3. ProcessEngineLifecycleListener接口说明
ProcessEngineLifecycleListener接口的具体定义如下:
public interface ProcessEngineLifecycleListener {
//process-engine 构建的时候调用
void onProcessEngineBuilt(ProcessEngine processEngine);
//process-engine 关闭的时候调用
void onProcessEngineClosed(ProcessEngine processEngine);
}
1.1.2.4. 自义类实现
上面的两种方式都需要自定义类myProcessEngineLifecycleListener,myProcessEngineLifecycleListener类的具体实现如下所示:
@Service("myProcessEngineLifecycleListener")
public class MyProcessEngineLifecycleListener implements ProcessEngineLifecycleListener{
private final Logger log = LoggerFactory.getLogger(this.getClass());
@Override
public void onProcessEngineBuilt(ProcessEngine processEngine) {
log.debug("processEngine:onProcessEngineBuilt{}", processEngine);
System.out.println("processEngine:onProcessEngineBuilt:"+processEngine);
}
@Override
public void onProcessEngineClosed(ProcessEngine processEngine) {
log.debug("processEngine:onProcessEngineClosed{}", processEngine);
System.out.println("processEngine:onProcessEngineBuilt:"+processEngine);
}
}
这样就大功告成了,只需要在onProcessEngineBuilt()和onProcessEngineClosed()两个方法中书写自己的业务逻辑即可。
onProcessEngineBuilt():activiti 工作流引擎构建的时候执行。
onProcessEngineClosed():activiti 工作流引擎销毁的时候执行。
1.1.3. 源码解读
上面的配置生效的话,确实能实现我们需要的功能,那问题来了,activiti 工作流引擎是如何处理的呢?知其然还要知其所以然,下面我们就来看看底层是如何处理的。
主要看ProcessEngineImpl activiti 工作流引擎的核心实现类,看一下这个类的构造方法,具体实现如下:
public ProcessEngineImpl(ProcessEngineConfigurationImpl processEngineConfiguration) {
...
//获取配置文件信息,就是上面中的两种配置方式中processEngineLifecycleListener具体实现类
if (processEngineConfiguration.getProcessEngineLifecycleListener() != null) {
processEngineConfiguration.getProcessEngineLifecycleListener().onProcessEngineBuilt(this);
}
}
上面的代码可以清晰的看到,ctiviti 工作流引擎启动的时候实例化ProcessEngineImpl 类的时候直接触发了onProcessEngineBuilt方法.
那onProcessEngineClosed()方法在什么时候被触发呢?
很明显,要是经验丰富,对spring比较了解的朋友一下子就想到了close()方法,没错就是ProcessEngineImpl种的close()方法实现的。close()方法实现如下所示:
public void close() {
...
if (processEngineConfiguration.getProcessEngineLifecycleListener() != null) {
processEngineConfiguration.getProcessEngineLifecycleListener().onProcessEngineClosed(this);
}
...
}
上面的close()方法中确实调用了onProcessEngineClosed()方法。
ok,关于这个processEngineLifecycleListener使用,我们就详细介绍到这里。
activiti processEngineLifecycleListener使用的更多相关文章
- 流程开发Activiti 与SpringMVC整合实例
流程(Activiti) 流程是完成一系列有序动作的概述.每一个节点动作的结果将对后面的具体操作步骤产生影响.信息化系统中流程的功能完全等同于纸上办公的层级审批,尤其在oa系统中各类电子流提现较为明显 ...
- activiti工作流的web流程设计器整合视频教程 SSM和独立部署
本视频为activiti工作流的web流程设计器整合视频教程 整合Acitiviti在线流程设计器(Activiti-Modeler 5.21.0 官方流程设计器) 本视频共讲了两种整合方式 1. 流 ...
- activiti工作流的web流程设计器整合视频教程 SSM 和 独立部署
本视频为activiti工作流的web流程设计器整合视频教程 整合Acitiviti在线流程设计器(Activiti-Modeler 5.21.0 官方流程设计器) 本视频共讲了两种整合方式 1. 流 ...
- 文档分享-Activiti 5.16 用户手册
今天在翻看工作流相关的网页的时候,在开源中国上http://www.oschina.net/question/915507_149175发现activiti的中文文档:http://www.mossl ...
- 1. Activiti 运行时表信息总结
Activiti的后台是有数据库的支持,所有的表都以ACT_开头. 第二部分是表示表的用途的两个字母标识. 用途也和服务的API对应. ACT_RE_*: 'RE'表示repository. 这个前缀 ...
- Activiti学习(二)数据表结构
Activiti工作流引擎数据库表结构 数据库表的命名 Acitiviti数据库中表的命名都是以ACT_开头的.第二部分是一个两个字符用例表的标识.此用例大体与服务API是匹配的. l ...
- Activiti学习(一) 环境搭建
原料:Activiti5.4 MyEclipse 10 1.先将activiti文件夹放置myeclipse的安装目录dropins文件夹下2.将activiti文件夹里activiti.link中 ...
- Activiti工作流学习(三)Activiti工作流与spring集成
一.前言 前面Activiti工作流的学习,说明了Activiti的基本应用,在我们开发中可以根据实际的业务参考Activiti的API去更好的理解以及巩固.我们实际的开发中我们基本上都使用sprin ...
- activiti当前任务高亮(解决乱码问题)
package com.xinwei; import java.io.File; import java.io.InputStream; import java.util.ArrayList; imp ...
随机推荐
- [LeetCode] Minimum Time Difference 最短时间差
Given a list of 24-hour clock time points in "Hour:Minutes" format, find the minimum minut ...
- 微信小程序开发•模块化
微信小程序的MINA框架,其实是许多前端开发技术的组合.这篇文章中,我们来简单地讨论一下模块化. 1.模块化标准 玩前端的同学大部分都知道模块化的几个标准,CommonJs / AMD / CMD.这 ...
- 机器学习技法:15 Matrix Factorization
Roadmap Linear Network Hypothesis Basic Matrix Factorization Stochastic Gradient Descent Summary of ...
- 树莓派控制HC-SR04超声波模块测距(新手向+C语言向)
因为作业要求使用c语言代码,这里先附上一段摘自网上的代码 感谢KalaerSun的c语言代码,摘自https://blog.csdn.net/qq_25247589/article/details/6 ...
- 【HNOI2017】大佬
题目描述 人们总是难免会碰到大佬.他们趾高气昂地谈论凡人不能理解的算法和数据结构,走到任何一个地方,大佬的气场就能让周围的人吓得瑟瑟发抖,不敢言语. 你作为一个 OIER,面对这样的事情非常不开心,于 ...
- bzoj 3998: [TJOI2015]弦论
Description 对于一个给定长度为N的字符串,求它的第K小子串是什么. Input 第一行是一个仅由小写英文字母构成的字符串S 第二行为两个整数T和K,T为0则表示不同位置的相同子串算作一个. ...
- Python入门之装饰器九步学习入门
第一步:最简单的函数,准备附加额外功能 '''示例1: 最简单的函数,表示调用了两次''' def myfunc(): print("myfunc() called.") myfu ...
- 关于惠普hp服务器开机时F10菜单变成F10 Function Disabled的解决方法
今天笔者由于在Intelligent Provisioning智能配置里不小心将"启动Intelligent Provisioning"选项钩选成禁用了,如下 结果就造成,在之后服 ...
- Spring常用接口和类
一.ApplicationContextAware接口 当一个类需要获取ApplicationContext实例时,可以让该类实现ApplicationContextAware接口.代码展示如下: p ...
- struts2 可以用ognl拿到值而不可以用el拿到值的解决方法
错误debug后 得到了There is no read method for container的错误 于是我new了一个实体类 package com.unity; public class St ...