免费观看又色又爽又黄的小说免费_美女福利视频国产片_亚洲欧美精品_美国一级大黄大色毛片

SpringBoot-定時任務分析

今天小編就為大家帶來一篇SpringBoot-定時任務分析的文章。小編覺得挺不錯的,為此分享給大家做個參考。一起跟隨小編過來看看吧。

遂溪網站制作公司哪家好,找創新互聯!從網頁設計、網站建設、微信開發、APP開發、響應式網站建設等網站項目制作,到程序開發,運營維護。創新互聯自2013年起到現在10年的時間,我們擁有了豐富的建站經驗和運維經驗,來保證我們的工作的順利進行。專注于網站建設就選創新互聯。

在我們實際開發項目的過程中,經常需要定時任務來幫我們做一些事情,例如每隔一小時統計新注冊的用戶數量、每天凌晨一點進行服務器緩存清理、每周五統計購買會員的用戶數量等。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-定時任務分析的詳細內容了,看完之后是否有所收獲呢?如果想了解更多相關內容,歡迎關注創新互聯行業資訊!

當前文章:SpringBoot-定時任務分析
文章位置:http://m.newbst.com/article26/ppisjg.html

成都網站建設公司_創新互聯,為您提供商城網站自適應網站域名注冊關鍵詞優化建站公司

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

成都網頁設計公司