Spring scheduler调度计划

  Spring调度类似Quartz机制,Quartz是一个非常有用的库,适用于具有更复杂调度要求的应用,而Spring的调度只需要一个@Scheduled,加入任何一个你需要定时执行的方法,并使用linux cron格式写入时间,其余都是SpringBoot自己来照顾执行,Spring Boot在内部使用该TaskScheduler接口来调度带注释的执行方法。

  只需将@EnableScheduling注释添加到主应用程序类或其中一个配置类,即可启用调度@Scheduled标注的方法,注意一共是两个步骤:@EnableScheduling 和 @Scheduled 分别标注。

如下:

@SpringBootApplication
@EnableScheduling
public class SpringbatchApplication {

public static void main(String[] args) {
SpringApplication.run(SpringbatchApplication.class, args);
}
}

 

我们以前面的SpringBatch为案例,我们希望定期执行这个批处理转换,那么只要在@Configuration类中加入调用计划方法:

   @Autowired
private Job importUserJob ;

// This job runs in every 5 seconds
@Scheduled(fixedRate = 5000)
public void printMessage() {
try {
JobParameters jobParameters = new JobParametersBuilder().addLong(
"time", System.currentTimeMillis()).toJobParameters();
jobLauncher.run(importUserJob, jobParameters);
System.out.println("I have been scheduled with Spring scheduler");
} catch (Exception e) {
e.printStackTrace();
}
}

其中importUserJob是我们Spring batch的导入User数据的Job,我们新增了方法printMessage,然后定义了@Scheduled(fixedRate = 5000),5秒执行一次importUserJob这个任务。

其他调度写法:

@Scheduled(cron = "0 * * * * ?")

上面是每分钟执行一次任务。

默认情况下,所有@Scheduled任务都在Spring创建的大小为1的默认线程池中执行。我们可以创建自己的线程池并配置Spring以使用该线程池来执行所有计划任务:

@Configuration
public class SchedulerConfig implements SchedulingConfigurer {
private final int POOL_SIZE = 10;

@Override
public void configureTasks(ScheduledTaskRegistrar scheduledTaskRegistrar) {
ThreadPoolTaskScheduler threadPoolTaskScheduler = new ThreadPoolTaskScheduler();

threadPoolTaskScheduler.setPoolSize(POOL_SIZE);
threadPoolTaskScheduler.setThreadNamePrefix("my-scheduled-task-pool-");
threadPoolTaskScheduler.initialize();

scheduledTaskRegistrar.setTaskScheduler(threadPoolTaskScheduler);
}
}

这就是配置Spring以使用自己的线程池而不是默认线程池所需要做的全部工作。

Spring Batch