最近在看activiti官方文档,英文水平有限,仅限个人理解。
一、简介
和Job Executor相对应,activiti从5.17.0版本开始提供性能更好,数据库更友好的Async Executor 来执行异步任务,所以activiti推荐使用Async Executor。
使用java EE7,ManagedJobExecutor
和ManagedAsyncJobExecutor
可以使用容器来管理线程,需要配置如下
<bean id="threadFactory" class="org.springframework.jndi.JndiObjectFactoryBean">
<property name="jndiName" value="java:jboss/ee/concurrency/factory/default" />
</bean>
<bean id="customJobExecutor" class="org.activiti.engine.impl.jobexecutor.ManagedJobExecutor">
<!-- ... -->
<property name="threadFactory" ref="threadFactory" />
<!-- ... -->
</bean>
二、Job executor activation
Job executor是管理几个线程计时器的组成部分(之后也是异步消息)。单元测试中,Job executor对多线程的处理较为笨重缓慢。所以API中提供了ManagementService.createJobQuery和ManagementService.executeJob来查询和执行任务。通过API,可以在单元测试中管理任务。为了避免冲突,job executor是可以被关闭的。
工作流引擎初始化时,job executor默认是被激活的,如果不想激活,配置如下
<property name="jobExecutorActivate" value="false" />
二、Async executor activation
Async executor通过线程池的方式管理线程。activiti默认激活使用job executor,要使用async executor替代job executor需在配置文件中定义一下两个属性<property name="asyncExecutorEnabled" value="true" />
<property name="asyncExecutorActivate" value="true" />
属性asyncExecutorEnabled定义为true,使用async executor代替默认的job executor;
属性asyncExecutorActivate定义为true,工作流引擎在启动时就建立启动async executor线程池