小編給大家分享一下創(chuàng)建springboot定時任務的方法,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
確山ssl適用于網(wǎng)站、小程序/APP、API接口等需要進行數(shù)據(jù)傳輸應用場景,ssl證書未來市場廣闊!成為成都創(chuàng)新互聯(lián)公司的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:13518219792(備注:SSL證書合作)期待與您的合作!
使用SpringBoot創(chuàng)建定時任務非常簡單,目前主要有以下三種創(chuàng)建方式:
一、基于注解(@Scheduled)
二、基于接口(SchedulingConfigurer) 前者相信大家都很熟悉,但是實際使用中我們往往想從數(shù)據(jù)庫中讀取指定時間來動態(tài)執(zhí)行定時任務,這時候基于接口的定時任務就派上用場了。
三、基于注解設定多線程定時任務
一、靜態(tài):基于注解
基于注解@Scheduled
默認為單線程,開啟多個任務時,任務的執(zhí)行時機會受上一個任務執(zhí)行時間的影響。
1、創(chuàng)建定時器
使用SpringBoot基于注解來創(chuàng)建定時任務非常簡單,只需幾行代碼便可完成。 代碼如下:
@Component @Configuration //1.主要用于標記配置類,兼?zhèn)銫omponent的效果。 @EnableScheduling // 2.開啟定時任務 public class SaticScheduleTask { //3.添加定時任務 @Scheduled(cron = "0/5 * * * * ?") //或直接指定時間間隔,例如:5秒 //@Scheduled(fixedRate=5000) private void configureTasks() { System.err.println("執(zhí)行靜態(tài)定時任務時間: " + LocalDateTime.now()); } }
Cron表達式參數(shù)分別表示:
秒(0~59) 例如0/5表示每5秒
分(0~59)
時(0~23)
日(0~31)的某天,需計算
月(0~11)
周幾( 可填1-7 或 SUN/MON/TUE/WED/THU/FRI/SAT)
@Scheduled:除了支持靈活的參數(shù)表達式cron之外,還支持簡單的延時操作,例如 fixedDelay ,fixedRate 填寫相應的毫秒數(shù)即可。
2、啟動測試
啟動應用,可以看到控制臺打印出如下信息:
顯然,使用@Scheduled 注解很方便,但缺點是當我們調整了執(zhí)行周期的時候,需要重啟應用才能生效,這多少有些不方便。為了達到實時生效的效果,可以使用接口來完成定時任務。
二、動態(tài):基于接口
基于接口(SchedulingConfigurer
)
1、導入依賴包
org.springframework.boot spring-boot-starter 2.0.4.RELEASE org.springframework.boot spring-boot-starter-web mysql mysql-connector-java org.mybatis.spring.boot mybatis-spring-boot-starter 1.3.1 org.mybatis mybatis 3.4.5 compile
2、添加數(shù)據(jù)庫記錄
開啟本地數(shù)據(jù)庫mysql,隨便打開查詢窗口,然后執(zhí)行腳本內容,如下:
DROP DATABASE IF EXISTS `socks`; CREATE DATABASE `socks`; USE `SOCKS`; DROP TABLE IF EXISTS `cron`; CREATE TABLE `cron` ( `cron_id` varchar(30) NOT NULL PRIMARY KEY, `cron` varchar(30) NOT NULL ); INSERT INTO `cron` VALUES ('1', '0/5 * * * * ?');
然后在項目中的application.yml 添加數(shù)據(jù)源:
spring: datasource: url: jdbc:mysql://localhost:3306/socks username: root password: 123456
3、創(chuàng)建定時器
數(shù)據(jù)庫準備好數(shù)據(jù)之后,我們編寫定時任務,注意這里添加的是TriggerTask,目的是循環(huán)讀取我們在數(shù)據(jù)庫設置好的執(zhí)行周期,以及執(zhí)行相關定時任務的內容。
具體代碼如下:
@Component @Configuration //1.主要用于標記配置類,兼?zhèn)銫omponent的效果。 @EnableScheduling // 2.開啟定時任務 public class DynamicScheduleTask implements SchedulingConfigurer { @Mapper public interface CronMapper { @Select("select cron from cron limit 1") public String getCron(); } @Autowired //注入mapper @SuppressWarnings("all") CronMapper cronMapper; /** * 執(zhí)行定時任務. */ @Override public void configureTasks(ScheduledTaskRegistrar taskRegistrar) { taskRegistrar.addTriggerTask( //1.添加任務內容(Runnable) () -> System.out.println("執(zhí)行動態(tài)定時任務: " + LocalDateTime.now().toLocalTime()), //2.設置執(zhí)行周期(Trigger) triggerContext -> { //2.1 從數(shù)據(jù)庫獲取執(zhí)行周期 String cron = cronMapper.getCron(); //2.2 合法性校驗. if (StringUtils.isEmpty(cron)) { // Omitted Code .. } //2.3 返回執(zhí)行周期(Date) return new CronTrigger(cron).nextExecutionTime(triggerContext); } ); } }
4、啟動測試
啟動應用后,查看控制臺,打印時間是我們預期的每10秒一次:
然后打開Navicat ,將執(zhí)行周期修改為每6秒執(zhí)行一次,如圖:
查看控制臺,發(fā)現(xiàn)執(zhí)行周期已經(jīng)改變,并且不需要我們重啟應用,十分方便。如圖:
注意:如果在數(shù)據(jù)庫修改時格式出現(xiàn)錯誤,則定時任務會停止,即使重新修改正確;此時只能重新啟動項目才能恢復。
三、多線程定時任務
基于注解設定多線程定時任務
1、創(chuàng)建多線程定時任務
//@Component注解用于對那些比較中立的類進行注釋; //相對與在持久層、業(yè)務層和控制層分別采用 @Repository、@Service 和 @Controller 對分層中的類進行注釋 @Component @EnableScheduling // 1.開啟定時任務 @EnableAsync // 2.開啟多線程 public class MultithreadScheduleTask { @Async @Scheduled(fixedDelay = 1000) //間隔1秒 public void first() throws InterruptedException { System.out.println("第一個定時任務開始 : " + LocalDateTime.now().toLocalTime() + "\r\n線程 : " + Thread.currentThread().getName()); System.out.println(); Thread.sleep(1000 * 10); } @Async @Scheduled(fixedDelay = 2000) public void second() { System.out.println("第二個定時任務開始 : " + LocalDateTime.now().toLocalTime() + "\r\n線程 : " + Thread.currentThread().getName()); System.out.println(); } }
2、啟動測試
啟動應用后,查看控制臺:
從控制臺可以看出,第一個定時任務和第二個定時任務互不影響;
并且,由于開啟了多線程,第一個任務的執(zhí)行時間也不受其本身執(zhí)行時間的限制,所以需要注意可能會出現(xiàn)重復操作導致數(shù)據(jù)異常。
以上是創(chuàng)建springboot定時任務的方法的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道!