您好,登錄后才能下訂單哦!
今天小編就為大家帶來一篇SpringBoot-定時任務分析的文章。小編覺得挺不錯的,為此分享給大家做個參考。一起跟隨小編過來看看吧。
在我們實際開發項目的過程中,經常需要定時任務來幫我們做一些事情,例如每隔一小時統計新注冊的用戶數量、每天凌晨一點進行服務器緩存清理、每周五統計購買會員的用戶數量等。SpringBoot在2.0版本之后,提供了非常方便的注解方式來編寫定時任務程序,無需添加任何配置文件和依賴關系,快速構建一個SpringBoot項目,添加注解如下:
@SpringBootApplication @EnableScheduling public class DemoApplication { public static void main(String[] args) { SpringApplication.run(DemoApplication.class, args); } }
@EnableScheduling:開啟對定時任務的支持
注解方式-單線程
創建SchedulerTask1類存放與task包下:
@Component public class SchedulerTask1 { @Scheduled(cron = "*/6 * * * * ?") private void process(){ System.out.println("SchedulerTask1 : " + LocalDateTime.now().toLocalTime() + "\r\n線程 : " + Thread.currentThread().getName()); } }
創建SchedulerTask2類存放與task包下:
@Component public class SchedulerTask2 { @Scheduled(fixedRate = 3000) private void process(){ System.out.println("SchedulerTask2 : " + LocalDateTime.now().toLocalTime() + "\r\n線程 : " + Thread.currentThread().getName()); } }
@Scheduled 參數可以接受兩種定時的設置,一種是我們常用的cron="*/6 * * * * ?",一種是 fixedRate = 3000,兩種都表示每隔X秒打印一下內容。
fixedRate 說明
@Scheduled(fixedRate = 3000) :上一次開始執行時間點之后3秒再執行
@Scheduled(fixedDelay = 3000) :上一次執行完畢時間點之后3秒再執行
@Scheduled(initialDelay=1000, fixedRate=6000) :第一次延遲1秒后執行,之后按
fixedRate 的規則每6秒執行一次
Cron表達式參數分別表示:
秒(0~59) 例如0/5表示每5秒
分(0~59)
時(0~23)
日(0~31)的某天,需計算
月(0~11)
周幾( 可填1-7 或 SUN/MON/TUE/WED/THU/FRI/SAT)
啟動項目,執行結果如下:
SchedulerTask2 : 21:36:47.795008800 線程 : scheduling-1 SchedulerTask1 : 21:36:48.014888600 線程 : scheduling-1 SchedulerTask2 : 21:36:50.792887400 線程 : scheduling-1 SchedulerTask2 : 21:36:53.792697900 線程 : scheduling-1 SchedulerTask1 : 21:36:54.002684700 線程 : scheduling-1 SchedulerTask2 : 21:36:56.792517700 線程 : scheduling-1 SchedulerTask2 : 21:36:59.792606400 線程 : scheduling-1 SchedulerTask1 : 21:37:00.002598400 線程 : scheduling-1 SchedulerTask2 : 21:37:02.792423300 線程 : scheduling-1 SchedulerTask2 : 21:37:05.802238 線程 : scheduling-1 SchedulerTask1 : 21:37:06.002225200 線程 : scheduling-1
可以看到,當上面兩個定時任務同時執行時,用的是同一個線程:scheduling-1,任務的執行時機會受上一個任務執行時間的影響。
注解方式-多線程
新建MultithreadScheduleTask類存放與task包下:
@Component @EnableAsync public class MultithreadScheduleTask { @Async @Scheduled(fixedDelay = 1000) public void first() throws InterruptedException { System.out.println("第一個定時任務開始 : " + LocalDateTime.now().toLocalTime() + "\r\n線程 : " + Thread.currentThread().getName()); 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(); } }
@EnableAsync:開啟多線程
啟動項目,運行結果如下:
第一個定時任務開始 : 21:48:47.121991300 線程 : task-1 第二個定時任務開始 : 21:48:47.121991300 線程 : task-2 第一個定時任務開始 : 21:48:48.121930600 線程 : task-3 第二個定時任務開始 : 21:48:49.114640 線程 : task-4 第一個定時任務開始 : 21:48:49.114640 線程 : task-5 第一個定時任務開始 : 21:48:50.119792400 線程 : task-6 第二個定時任務開始 : 21:48:51.119726900 線程 : task-7 第一個定時任務開始 : 21:48:51.129727800 線程 : task-8 第一個定時任務開始 : 21:48:52.130157200 線程 : task-2 第二個定時任務開始 : 21:48:53.120096500 線程 : task-4 第一個定時任務開始 : 21:48:53.140095 線程 : task-7 第一個定時任務開始 : 21:48:54.140429600 線程 : task-4 第二個定時任務開始 : 21:48:57.130710 線程 : task-1
以上就是SpringBoot-定時任務分析的詳細內容了,看完之后是否有所收獲呢?如果想了解更多相關內容,歡迎關注億速云行業資訊!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。