fea*_*tur 5 spring spring-integration spring-batch
我有一个报告生成应用程序.由于准备此类报告是重量级的,因此它们与Spring Batch异步准备.使用HTTP通过REST接口创建此类报告的请求.
目标是REST资源简单地将报告执行排队并完成(如文档中所述).因此,为JobLauncher提供了一个TaskExecutor:
<bean id="jobLauncher" class="org.springframework.batch.core.launch.support.SimpleJobLauncher">
<property name="jobRepository" ref="jobRepository" />
<property name="taskExecutor">
<bean class="org.springframework.core.task.SimpleAsyncTaskExecutor"/>
</property>
</bean>
Run Code Online (Sandbox Code Playgroud)
由于报告非常重量级,因此在给定时间内只能生成指定数量的报告.希望能够将Spring Batch配置为一次只生成2个实例,已指定concurrencyLimit:
<bean id="jobLauncher" class="org.springframework.batch.core.launch.support.SimpleJobLauncher">
<property name="jobRepository" ref="jobRepository" />
<property name="taskExecutor">
<bean class="org.springframework.core.task.SimpleAsyncTaskExecutor">
<property name="concurrencyLimit" value="2" />
</bean>
</property>
</bean>
Run Code Online (Sandbox Code Playgroud)
不幸的是,当2个作业已经运行时,启动作业调用被阻止:jobLauncher.run(job,builder.toJobParameters());
显然jobLauncher会立即尝试执行作业.我想象一旦线程可用,它就会排队执行作业.这样,我可以通过简单地添加其他处理实例来扩展我的应用程序,所有这些都使用相同的作业存储库
在这里问了类似的问题.我即将开始探索Spring Batch Integration,但我不确定这是否是正确的方向.
我的用例对我来说似乎并不常见,难道不应该有一个广泛讨论的模式,我显然无法找到它吗?
谢谢f
Mic*_*lla 11
SimpleAsyncTaskExecutor不建议大量使用,因为它会为每个任务生成一个新线程.它也不支持更强大的概念,如线程池和任务排队.
如果你看看ThreadPoolTaskExecutor它,它支持更强大的任务执行范例,例如排队任务和使用线程池而不是产生随机的,未重用的线程.
你可以ThreadPoolTaskExecutor在这里阅读更多关于javadoc的内容:http://docs.spring.io/spring/docs/current/javadoc-api/org/springframework/scheduling/concurrent/ThreadPoolTaskExecutor.html
这有帮助,非常感谢。替换 SimpleAsyncTaskExecutor 后,我就得到了我需要的东西。代码:
@Bean
public TaskExecutor jobLauncherTaskExecutor() {
ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
executor.setMaxPoolSize(executorsPoolSize);
executor.setCorePoolSize(executorsPoolSize);
return executor;
}
Run Code Online (Sandbox Code Playgroud)
谢谢 f
| 归档时间: |
|
| 查看次数: |
9977 次 |
| 最近记录: |