您好,登錄后才能下訂單哦!
SpringBoot添加定時任務入門請看這里=>SpringBoot入門八,添加定時任務
Task定時任務默認都是使用單線程執行的,如果定時任務有很多的話,那么可能會導致很多任務無法按時準確執行,示例如下:
import java.text.SimpleDateFormat;
import java.util.Date;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
@Component
public class TaskTest {
private final Logger log = LoggerFactory.getLogger(TaskTest02.class);
//輸出時間格式
private static final SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss:sss");
@Scheduled(cron = "0/15 * * * * ? ")
private void sayHello(){
String dateTime = format.format(new Date());
log.info("{} 向宇宙發出了一聲問候: Hello World!", dateTime);
try {
Thread.sleep(10000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
@Scheduled(cron = "0/16 * * * * ? ")
private void sayHello2(){
String dateTime = format.format(new Date());
log.info("{} 向宇宙發出了一聲問候: 你好,世界", dateTime);
}
}
當sayHello()方法執行的時候,因為長時間占用任務執行線程,導致sayHello2()被迫向后延時執行,如圖:
添加以下代碼塊,可放置在任意一個類中,整個工程只需要添加一個即可
@Bean
public TaskScheduler taskScheduler() {
ThreadPoolTaskScheduler scheduler = new ThreadPoolTaskScheduler();
// 設置scheduler執行線程為3個
scheduler.setPoolSize(3);
return scheduler;
}
添加一個配置類即可,定時任務類或方法不用做任何改變
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.scheduling.TaskScheduler;
import org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler;
/**
* @描述: 多線程執行定時任務
* @日期 2019年5月28日
*/
@Configuration
public class TaskConfig {
/**
* @描述: 所有的定時任務都放在一個線程池中,定時任務啟動時使用不同的線程
* @return
* @日期 2019年5月28日
*/
@Bean
public TaskScheduler taskScheduler() {
ThreadPoolTaskScheduler scheduler = new ThreadPoolTaskScheduler();
// 設置scheduler執行線程為3個
scheduler.setPoolSize(3);
return scheduler;
}
}
添加一個配置類即可(實現SchedulingConfigurer接口),定時任務類或方法不用做任何改變
import java.util.concurrent.Executors;
import org.springframework.context.annotation.Configuration;
import org.springframework.scheduling.annotation.SchedulingConfigurer;
import org.springframework.scheduling.config.ScheduledTaskRegistrar;
/**
* @描述: 多線程執行定時任務
* @日期 2019年5月27日
*/
@Configuration
public class SchedulingConfig implements SchedulingConfigurer {
/**
* @描述: 所有的定時任務都放在一個線程池中,定時任務啟動時使用不同的線程
* @param taskRegistrar
* @日期 2019年5月27日
*/
@Override
public void configureTasks(ScheduledTaskRegistrar taskRegistrar) {
//設定一個定時任務線程池,數量為3
taskRegistrar.setScheduler(Executors.newScheduledThreadPool(3));
}
}
可以看到兩個定時任務已經分別由不同的線程執行了
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。