package com.ld.igds.conf;
|
|
import org.springframework.context.annotation.Configuration;
|
import org.springframework.scheduling.annotation.EnableScheduling;
|
import org.springframework.scheduling.annotation.SchedulingConfigurer;
|
import org.springframework.scheduling.config.ScheduledTaskRegistrar;
|
|
import java.util.concurrent.Executors;
|
|
/**
|
* 启用SpringBoot定时任务-- 启用多线程方案
|
*
|
* @author: andy.jia
|
* @description:
|
* @version:
|
* @data:2019年12月7日
|
*/
|
@Configuration
|
@EnableScheduling
|
public class SchedulingConfig implements SchedulingConfigurer {
|
@Override
|
public void configureTasks(ScheduledTaskRegistrar taskRegistrar) {
|
|
//当然了,这里设置的线程池是corePoolSize也是很关键了,自己根据业务需求设定
|
taskRegistrar.setScheduler(Executors.newScheduledThreadPool(5));
|
|
|
/**为什么这么说呢?
|
假设你有4个任务需要每隔1秒执行,而其中三个都是比较耗时的操作可能需要10多秒,而你上面的语句是这样写的:
|
taskRegistrar.setScheduler(newScheduledThreadPool(3));
|
那么仍然可能导致最后一个任务被阻塞不能定时执行
|
**/
|
}
|
|
|
}
|