我有一个Spring Batch作业,可以跨多个服务器运行。我有一个监听器,可以防止在一台服务器上同时运行作业的多个实例。但是,我想确保不能在多台服务器上同时运行此作业。
我搜索并没有找到解决此问题的方法
最佳答案
我实现了一个监听器,该监听器检查与特定名称匹配的spring批处理控制表中正在运行的Job Execution的数量。如果执行的大小超过1,则当前作业的jobExecution将失败。这是代码:
@Component
public class SingleInstanceListener implements JobExecutionListener {
@Autowired
private JobExplorer explorer;
@Override
public void beforeJob(JobExecution jobExecution) {
String jobName = jobExecution.getJobInstance().getJobName();
Set<JobExecution> executions = explorer.findRunningJobExecutions(jobName);
if(executions.size() > 1) {
jobExecution.stop();
}
}
@Override
public void afterJob(JobExecution jobExecution) {
}
}