如何控制并行Spring Batch作业的数量

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/ThreadPoolTask​​Executor.html


fea*_*tur 6

这有帮助,非常感谢。替换 SimpleAsyncTaskExecutor 后,我就得到了我需要的东西。代码:

@Bean
public TaskExecutor jobLauncherTaskExecutor() {
    ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
    executor.setMaxPoolSize(executorsPoolSize);
    executor.setCorePoolSize(executorsPoolSize);
    return executor;
}
Run Code Online (Sandbox Code Playgroud)

谢谢 f