springboot 多线程定时任务

1.单线程任务

TestSchedule.java代码:

@Component
public class TestSchedule {
	
	private static Logger log = LoggerFactory.getLogger(TestSchedule.class);
	
	//上一次任务执行完成1秒后再次执行
	@Scheduled(fixedDelay = 1000)
	public void test1(){
		log.info("=========Test1执行=========");
	}
	
	//上一次任务开始执行1秒后再次执行
	@Scheduled(fixedRate = 1000)
	public void test2(){
		log.info("=========Test2执行=========");
	}
	
	//第一次延迟1秒执行,从第一次开始执行每3秒执行一次
	@Scheduled(initialDelay = 1000, fixedRate = 3000)
	public void test3(){
		log.info("=========Test3执行=========");
	}
	
	//上一次任务执行完成2秒后再次执行
	@Scheduled(fixedDelayString = "2000")
	public void test4(){
		log.info("=========Test4执行=========");
	}
	
	//每隔5秒执行一次
	@Scheduled(cron = "0/5 * * * * ?")
	public void test5(){
		log.info("=========Test5执行=========");
	}
}

ScheduleApplication.java代码:

@SpringBootApplication
@EnableScheduling
public class ScheduleApplication {

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

注:@EnableScheduling注解用于发现@Scheduled注解,不添加@EnableScheduling定时任务将不起作用。

启动服务测试:

springboot 多线程定时任务_第1张图片
如图,5个任务只在一个线程里运行,这种情况下任务只能是一个执行完毕再执行另一个,而有些场景需要同时执行多个任务。

2.多线程任务

参考@EnableScheduling注解中的注释:
springboot 多线程定时任务_第2张图片
如图,我们只需要添加一个配置类并实现SchedulingConfigurer接口,然后在configureTasks方法中设置线程池就行了。

ScheduleConfig.java代码:

@Configuration
public class ScheduleConfig implements SchedulingConfigurer {
	
    @Override
    public void configureTasks(ScheduledTaskRegistrar taskRegistrar) {
        taskRegistrar.setScheduler(taskExecutor());
    }

    @Bean(destroyMethod="shutdown")
    public Executor taskExecutor() {
        return Executors.newScheduledThreadPool(5);
    }
}

启动服务测试:

springboot 多线程定时任务_第3张图片
通过输出日志可以看到多个任务成功运行在了多个线程中。

参考网站:

  • https://blog.csdn.net/u013456370/article/details/79411952

你可能感兴趣的:(Spring,Boot)