@Scheduled 注解定时任务的坑
其实@Scheduled注解应该蛮多人在用,是spring自带的一个蛮方便的定时任务,加上一个注解就可以了,简单易用,但是很多人不知道其中的坑,可能会出现的问题有某天的定时任务突然不执行或延迟执行,这是因为这个定时任务的默认线程数是1,因为如果一个进程里配置了多个定时任务时,其中一个线程没跑完或者阻塞,就会导致其他线程数阻塞不执行或者延迟执行,因为可能会导致程序出现一些不可预计的奇怪现象。
可以看到只有一个线程执行定时任务。
修改默认的线程数:
import com.google.common.util.concurrent.ThreadFactoryBuilder;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import java.util.concurrent.ScheduledThreadPoolExecutor;
import java.util.concurrent.ThreadFactory;
@Configuration
public class ScheduledConfig {
@Value("${scheduled.corePoolSize:10}")
private int corePoolSize = 10;
@Bean
public ScheduledThreadPoolExecutor scheduledExecutorService() {
ThreadFactory namedThreadFactory = new ThreadFactoryBuilder().setNameFormat("scheduledThreadPool-%d").build();
ScheduledThreadPoolExecutor executor = new ScheduledThreadPoolExecutor(corePoolSize, namedThreadFactory);
return executor;
}
}
这个时候看到,由两个线程执行了定时任务,也不会出现阻塞的情况了。