内容概况:

异步执行配置相关:

asyncExecutorActivate:这个属性是激活作业执行器,它的默认参数是false,只有设为true,activiti启动的时候才会开启线程池去扫描定时操作的任务

asyncExecutorXXX:这些属性的操作都是基于asyncExecutor这样一个前缀,后面有各种类型的属性配置,(其实里面的属性配置大多都是与线程池、队列相关的配置)

(很重要的配置)asyncExecutor:asyncExecutor的bean的配置,它本身是一个接口,用它也可以配置自定义的线程池。

如何自定义一个线程池?

在设置了核心线程数的情况下,比如设为了5,那么在开启了五个线程之后,有新的任务来了之后,回去检测核心线程数是否都在执行任务中,如果是,那么新的请求就会放在队列里去等待,

等到核心线程中有一个线程执行完了自己的任务,那么排在队列最前面的这个请求,回去获取这个线程,然后去执行。那么当队列一直有新的请求加入时,负载过大,超过了队列大小的时候,最大线程数就会起作用了,新建线程至最大线程数,来一起执行超过容量的新请求。  当三个都满了以后,就会拒绝服务、请求。


作业执行器的配置:

这里要说明的是R5/P1DT1H, / 后面的指时间间隔,1D表示一天,是24个小时,而1H表示一小时加起来就是25个小时。R5是指执行次数为5,这个属性的含义是:在流程启动时开始计时,25小时后第一次执行这个指定事件, 并且每隔25小时执行一次,总共执行次数为5次(ps:包含第一次执行在内)。


流程定义文件my-process_job.bpmn20.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"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd"> <bean id="processEngineConfiguration"
class="org.activiti.engine.impl.cfg.StandaloneInMemProcessEngineConfiguration">
<!-- 给引擎设置自定义的commandInvoker -->
<!--<property name="commandInvoker" ref="commandInvoker" />-->
<!-- 若为true则开启记录事件、节点的状态,完成后将完成状态插入数据库,若为false则关闭,不记录 -->
<property name="enableDatabaseEventLogging" value="true"/> <!--打开异步激活器激活异步,如果不配置线程池就会使用它的默认线程池-->
<property name="asyncExecutorActivate" value="true"/>
<!--如果使用我们自己定义的线程池,需要先定义一个执行器-->
<property name="asyncExecutor" ref="asyncExecutor" />
<!-- 配置事件监听器 -->
<property name="eventListeners">
<list>
<bean class="com.yy.avtiviti.helloworld.event.JobEventListener"/>
</list>
</property>
</bean>
<!-- 执行器默认使用DefaultAsyncJobExecutor -->
<bean id="asyncExecutor"
class="org.activiti.engine.impl.asyncexecutor.DefaultAsyncJobExecutor">
<!-- 需要配置一个服务 基于spring去配置它 -->
<property name="executorService" ref="executorService"/>
</bean>
<bean id="executorService" class="org.springframework.scheduling.concurrent.ThreadPoolExecutorFactoryBean">
<property name="threadNamePrefix" value="activiti-job-"/>
<property name="corePoolSize" value="10"/>
<property name="maxPoolSize" value="20"/>
<property name="queueCapacity" value="100"/>
<!-- 设置当线程池满了时候的拒绝策略,这里是使用的默认策略,抛出异常 -->
<property name="rejectedExecutionHandler">
<bean class="java.util.concurrent.ThreadPoolExecutor$AbortPolicy"/>
</property>
</bean>
<bean id="commandInvoker" class="com.yy.avtiviti.helloworld.intercept.MDCCommandInvoker"/> </beans>

设置一个监听器JobEventListener,以便测试观察:

public class JobEventListener implements ActivitiEventListener {
private static final Logger LOGGER = LoggerFactory.getLogger(JobEventListener.class); //简单的完成一下监听器的效果
@Override
public void onEvent(ActivitiEvent event) {
ActivitiEventType eventType = event.getType();
String name = eventType.name(); if (name.startsWith("TIMER") || name.startsWith("JOB")){
LOGGER.info("监听到job事件 {} \t {}",eventType,event.getProcessInstanceId());
}
} @Override
public boolean isFailOnException() {
return false;
}
}

编写activiti配置文件activiti_job.cfg.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"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd"> <bean id="processEngineConfiguration"
class="org.activiti.engine.impl.cfg.StandaloneInMemProcessEngineConfiguration">
<!-- 给引擎设置自定义的commandInvoker -->
<!--<property name="commandInvoker" ref="commandInvoker" />-->
<!-- 若为true则开启记录事件、节点的状态,完成后将完成状态插入数据库,若为false则关闭,不记录 -->
<property name="enableDatabaseEventLogging" value="true"/> <!--打开异步激活器激活异步,如果不配置线程池就会使用它的默认线程池-->
<property name="asyncExecutorActivate" value="true"/>
<!--如果使用我们自己定义的线程池,需要先定义一个执行器-->
<property name="asyncExecutor" ref="asyncExecutor" />
<!-- 配置事件监听器 -->
<property name="eventListeners">
<list>
<bean class="com.yy.avtiviti.helloworld.event.JobEventListener"/>
</list>
</property>
</bean>
<!-- 执行器默认使用DefaultAsyncJobExecutor -->
<bean id="asyncExecutor"
class="org.activiti.engine.impl.asyncexecutor.DefaultAsyncJobExecutor">
<!-- 需要配置一个服务 基于spring去配置它 -->
<property name="executorService" ref="executorService"/>
</bean>
<bean id="executorService" class="org.springframework.scheduling.concurrent.ThreadPoolExecutorFactoryBean">
<property name="threadNamePrefix" value="activiti-job-"/>
<property name="corePoolSize" value="10"/>
<property name="maxPoolSize" value="20"/>
<property name="queueCapacity" value="100"/>
<!-- 设置当线程池满了时候的拒绝策略,这里是使用的默认策略,抛出异常 -->
<property name="rejectedExecutionHandler">
<bean class="java.util.concurrent.ThreadPoolExecutor$AbortPolicy"/>
</property>
</bean>
<bean id="commandInvoker" class="com.yy.avtiviti.helloworld.intercept.MDCCommandInvoker"/> </beans>

编写测试类configJobTest :

public class configJobTest {
private static final Logger LOGGER = LoggerFactory.getLogger(configTest.class); @Rule
public ActivitiRule activitiRule = new ActivitiRule("activiti_job.cfg.xml");//传入自定义的mdc配置文件 @Test
@Deployment(resources = {"my-process_job.bpmn20.xml"})//流程定义文件
public void test() throws InterruptedException {
//这里流程定义文件里设置了定时任务在一定事件内启动五次,所以不需要自行启动了。这里启动的代码就可以不要了。
//这里记录一下时间,看下流程每次启动时间与结束时间
LOGGER.info("start"); //在流程定义文件初始化以后,就开始定时启动了。
//那么我应该要查询一下在这段时间内有多少定时任务去执行
List<Job> jobList = activitiRule
.getManagementService()
.createTimerJobQuery()
.listPage(0, 100);
for (Job job : jobList) {
LOGGER.info("定时任务 {} ,默认重复次数 {}",job,job.getRetries());
}
LOGGER.info("jobList.size = {}",jobList.size());
//因为主线程很快就能执行完,而定时任务还没有执行,所以让线程等待一下
Thread.sleep(1000*10);
LOGGER.info("end"); }
}

测试结果如下:

Activiti6作业执行器Job Executor配置(学习笔记)的更多相关文章

  1. Chapter 2. OpenSSL的安装和配置学习笔记

    Chapter 2. OpenSSL的安装和配置学习笔记 2.1 在linux上面安装OpenSSL我还是做点No paper事情比较在行,正好和老师的课程接轨一下.以前尝试过在Windows上面安装 ...

  2. redis 安装配置学习笔记

    redis 安装配置学习笔记 //wget http://download.redis.io/releases/redis-2.8.17.tar.gz 下载最新版本 wget http://downl ...

  3. 作业执行器Job Executor

    Job Executor 激活作业执行器 AsyncExecutor是一个组件,它管理线程池,来触发计时器和其他异步任务.其他实现也是可能的(例如使用消息队列,请参阅用户指南的高级部分). 默认情况下 ...

  4. Elasticsearch的配置学习笔记

    文/朱季谦 Elasticsearch是一个基于Lucene的搜索服务器.它提供一个分布式多用户能力的全文搜索引擎,基于RESTful web接口,Elasticsearch是用Java语言开发的. ...

  5. Windows+Nginx+Tomcat整合的安装与配置学习笔记

    以下全部是nginx在window7下运行的: nginx学习总结: 我的是放在F盘 1.启动:F:\nginx-1.10.2\nginx-1.10.2>start nginx.exe(找到相应 ...

  6. Hive0.11安装配置学习笔记

    转:http://springsfeng.iteye.com/blog/1734517 1 . 首先请安装好MySQL并修改root账户密码,使用root账户执行下面命令:  su - root    ...

  7. php的具体配置学习笔记

    1.将php配置为apache的一个模块,使用loadmodule指令完成. 2.写下面的语句,此外需强调的是,每次配置都需要重新启动apache 3.php文件,要指定将其php模块来处理 4.PH ...

  8. linux配置学习笔记(一):如何提高ssh连接的速度

    服务器端sshd配置文件 /etc/ssh/sshd_config 看是否有如下的两条配置条目 GSSAPIAuthentication no UseDNS no 如果前面带#,请把#删掉,或者新添加 ...

  9. Executor框架学习笔记

    Java中的线程即是工作单元也是执行机制,从JDK 5后,工作单元与执行机制被分离.工作单元包括Runnable和Callable,执行机制由JDK 5中增加的java.util.concurrent ...

随机推荐

  1. Java开发笔记(七)强制类型转换的风险

    编码过程中,不但能将数字赋值给某个变量,还能将一个变量赋值给另一个变量.比如下面代码把整型变量changjiang赋值给整型变量longRiver: // 长江的长度为6397千米 int chang ...

  2. js 向上和向下取整

    Math.ceil(x),Math.floor(x) ◎Math.ceil()执行向上舍入,即它总是将数值向上舍入为最接近的整数:◎Math.floor()执行向下舍入,即它总是将数值向下舍入为最接近 ...

  3. 程序员奇谈之我写的程序不可能有bug篇

    程序员在普通人的印象里是一份严(ku)谨(bi)的职业,也是一个被搞怪吐槽乐此不疲的职业,程序员们面对复杂的代码敲打电脑时连眉头都不会皱一下,但是有一个词却是他们痛苦的根源,它就是Bug. 有不少的新 ...

  4. 一句话总结K均值算法

    一句话总结K均值算法 核心:把样本分配到离它最近的类中心所属的类,类中心由属于这个类的所有样本确定. k均值算法是一种无监督的聚类算法.算法将每个样本分配到离它最近的那个类中心所代表的类,而类中心的确 ...

  5. iOS----------取数据的两种取法

    NSMutableArray * dataArray =[responseDictionary valueForKeyPath:@"data.list_dic.list"]; NS ...

  6. ASP.NET MVC从空项目开始定制项目

    在上一篇net core的文章中已经讲过如何从零开始搭建WebSocket. 今天聊聊ASP.NET的文件结构,如何用自己的目录结构组织项目里的文件. 如果用Visual Studio(VS)向导或d ...

  7. spring学习总结——装配Bean学习四(导入和混合配置)

    情景:在典型的Spring应用中,我们可能会同时使用自动化和显式配置(JavaConfig)或者XML配置,幸好在Spring中,这些配置方案都不是互斥的.你尽可以将JavaConfig的组件扫描和自 ...

  8. SQL Server 迁移至MySQL 关键步骤的梳理总结

    迁移主要是通过Navicat工具来实现的.迁移工具的选定在此不讨论. 迁移前准备 1.提前通知DBA\SA\BI等,并确认发布计划及数据库迁移方案. 2.梳理出SQL  Server DB 中影响业务 ...

  9. linux $参数

    $# 是传给脚本的参数个数 $0 是脚本本身的名字 $1 是传递给该shell脚本的第一个参数 $2 是传递给该shell脚本的第二个参数 $@ 是传给脚本的所有参数的列表 $* 是以一个单字符串显示 ...

  10. windows环境下安装yaf框架

    windows环境下安装yaf框架 在windows下安装yaf框架 准备工作: php环境(过程略,wamp,xampp,phpstudy都行,php版本大于5.3) git工具(需要从github ...