spring中@Scheduled定时任务执⾏时间不准确问题
⼀、问题背景
使⽤@Scheduled创建两个定时任务,其中⼀个1s执⾏。另⼀个1min执⾏。按分钟执⾏的出现了bug,我设定的规则如下:
@Async
@Scheduled(cron = "0 0/1 * * * ?")
public void workOfMin() {
logger.info("---------》");
}
实际执⾏的时间不是每分钟00秒,⽽是随机的01~20之间。⽐如:每分钟的03、04、11秒执⾏任务。但是我要的结果是每分钟的00秒执⾏,必须精确。
⼆、解决⽅案
@SpringBootApplication
@EnableJpaRepositories(repositoryFactoryBeanClass = MyRepositoryFactoryBean.class)
@EnableTransactionManagement
@EnableAutoConfiguration
@EnableScheduling
@Configuration
@EnableDiscoveryClient
@EnableFeignClients
@EnableCaching
public class Application extends DefaultApplication {
spring framework runtime/**
*
*〈简述〉修复同⼀时间⽆法执⾏多个定时任务问题
*〈详细描述〉
*/
@Bean
public TaskScheduler taskScheduler() {
ThreadPoolTaskScheduler taskScheduler = new ThreadPoolTaskScheduler();
taskScheduler.setPoolSize(50);
return taskScheduler;
}
/**
* 〈简述〉应⽤启动⼊⼝
* 〈详细描述〉
*
* @param args String[] 参数
*/
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
创建⼀个@Bean⽅法,设置poolSize。原因是spring计划任务线程阻塞导致。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论