最近2018中文字幕在日韩欧美国产成人片_国产日韩精品一区二区在线_在线观看成年美女黄网色视频_国产精品一区三区五区_国产精彩刺激乱对白_看黄色黄大色黄片免费_人人超碰自拍cao_国产高清av在线_亚洲精品电影av_日韩美女尤物视频网站

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
深入淺析SpringBoot中的定時(shí)任務(wù)

今天就跟大家聊聊有關(guān)深入淺析SpringBoot中的定時(shí)任務(wù),可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

成都創(chuàng)新互聯(lián)為客戶提供專業(yè)的成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站制作、程序、域名、空間一條龍服務(wù),提供基于WEB的系統(tǒng)開發(fā). 服務(wù)項(xiàng)目涵蓋了網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站程序開發(fā)、WEB系統(tǒng)開發(fā)、微信二次開發(fā)、手機(jī)網(wǎng)站開發(fā)等網(wǎng)站方面業(yè)務(wù)。

1. 定時(shí)任務(wù)實(shí)現(xiàn)方式

定時(shí)任務(wù)實(shí)現(xiàn)方式:

  • Java自帶的java.util.Timer類,這個(gè)類允許你調(diào)度一個(gè)java.util.TimerTask任務(wù)。使用這種方式可以讓你的程序按照某一個(gè)頻度執(zhí)行,但不能在指定時(shí)間運(yùn)行。一般用的較少,這篇文章將不做詳細(xì)介紹。
  • 使用Quartz,這是一個(gè)功能比較強(qiáng)大的的調(diào)度器,可以讓你的程序在指定時(shí)間執(zhí)行,也可以按照某一個(gè)頻度執(zhí)行,配置起來(lái)稍顯復(fù)雜,有空介紹。
  • SpringBoot自帶的Scheduled,可以將它看成一個(gè)輕量級(jí)的Quartz,而且使用起來(lái)比Quartz簡(jiǎn)單許多,本文主要介紹。
     

定時(shí)任務(wù)執(zhí)行方式:

  • 單線程(串行)
  • 多線程(并行)

2. 創(chuàng)建定時(shí)任務(wù)

package com.autonavi.task.test;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;

import com.autonavi.task.ScheduledTasks;

@Component
public class ScheduledTest {

  private static final Logger logger = LoggerFactory.getLogger(ScheduledTasks.class);

  @Scheduled(cron="0 0/2 8-20 * * ?") 
  public void executeFileDownLoadTask() {

    // 間隔2分鐘,執(zhí)行工單上傳任務(wù)   
    Thread current = Thread.currentThread(); 
    System.out.println("定時(shí)任務(wù)1:"+current.getId());
    logger.info("ScheduledTest.executeFileDownLoadTask 定時(shí)任務(wù)1:"+current.getId()+ ",name:"+current.getName());
  }

  @Scheduled(cron="0 0/1 8-20 * * ?") 
  public void executeUploadTask() {

    // 間隔1分鐘,執(zhí)行工單上傳任務(wù)       
    Thread current = Thread.currentThread(); 
    System.out.println("定時(shí)任務(wù)2:"+current.getId());
    logger.info("ScheduledTest.executeUploadTask 定時(shí)任務(wù)2:"+current.getId() + ",name:"+current.getName());
  }

  @Scheduled(cron="0 0/3 5-23 * * ?") 
  public void executeUploadBackTask() {

    // 間隔3分鐘,執(zhí)行工單上傳任務(wù)             
    Thread current = Thread.currentThread(); 
    System.out.println("定時(shí)任務(wù)3:"+current.getId());
    logger.info("ScheduledTest.executeUploadBackTask 定時(shí)任務(wù)3:"+current.getId()+ ",name:"+current.getName());
  }  

}

@Scheduled 注解用于標(biāo)注這個(gè)方法是一個(gè)定時(shí)任務(wù)的方法,使用@Scheduled(cron=”…”) 表達(dá)式來(lái)設(shè)置定時(shí)任務(wù)。

// 每天早八點(diǎn)到晚八點(diǎn),間隔2分鐘執(zhí)行任務(wù)
@Scheduled(cron="0 0/2 8-20 * * ?") 
// 每天早八點(diǎn)到晚八點(diǎn),間隔3分鐘執(zhí)行任務(wù)
@Scheduled(cron="0 0/3 8-20 * * ?") 
// 每天早八點(diǎn)到晚八點(diǎn),間隔1分鐘執(zhí)行任務(wù)
@Scheduled(cron="0 0/1 8-20 * * ?") 

3. 啟動(dòng)定時(shí)任務(wù)

@ComponentScan
@EnableAutoConfiguration
@EnableScheduling
@Configuration
public class App {

  private static final Logger logger = LoggerFactory.getLogger(App.class);

  public static void main(String[] args) {

    SpringApplication.run(App.class, args);   
    logger.info("oops");            
  }  
}

其中 @EnableScheduling 注解的作用是發(fā)現(xiàn)注解@Scheduled的任務(wù)并后臺(tái)執(zhí)行。

4. 執(zhí)行結(jié)果

2016-02-14-14-51 [pool-2-thread-1] [com.autonavi.task.ScheduledTasks] [INFO] - ScheduledTest.executeUploadBackTask 定時(shí)任務(wù)3:15,name:pool-2-thread-1
   定時(shí)任務(wù)2:15
2016-02-14-14-51 [pool-2-thread-1] [com.autonavi.task.ScheduledTasks] [INFO] - ScheduledTest.executeUploadTask 定時(shí)任務(wù)2:15,name:pool-2-thread-1
   定時(shí)任務(wù)1:15
2016-02-14-14-52 [pool-2-thread-1] [com.autonavi.task.ScheduledTasks] [INFO] - ScheduledTest.executeFileDownLoadTask 定時(shí)任務(wù)1:15,name:pool-2-thread-1
   定時(shí)任務(wù)2:15
2016-02-14-14-52 [pool-2-thread-1] [com.autonavi.task.ScheduledTasks] [INFO] - ScheduledTest.executeUploadTask 定時(shí)任務(wù)2:15,name:pool-2-thread-1
   定時(shí)任務(wù)2:15
2016-02-14-14-53 [pool-2-thread-1] [com.autonavi.task.ScheduledTasks] [INFO] - ScheduledTest.executeUploadTask 定時(shí)任務(wù)2:15,name:pool-2-thread-1

5. 串行任務(wù)

上述方法可以實(shí)現(xiàn)定時(shí)任務(wù),方式也比較簡(jiǎn)單,不用配置什么文件啥的,但你會(huì)發(fā)現(xiàn)一個(gè)問題,就是不論定時(shí)任務(wù)被安排在多少個(gè)class類中,其依然是單線程執(zhí)行定時(shí)任務(wù)(串行任務(wù)):

2016-02-14-15-05 [pool-2-thread-1] [com.autonavi.task.ScheduledTasks] [INFO] - ScheduledTasks.executeUploadTask 定時(shí)任務(wù)1:15,name:pool-2-thread-1
   定時(shí)任務(wù)2:15
2016-02-14-15-06 [pool-2-thread-1] [com.autonavi.task.ScheduledTasks] [INFO] - ScheduledTest.executeUploadTask 定時(shí)任務(wù)2:15,name:pool-2-thread-1

上述執(zhí)行結(jié)果中ScheduledTest和ScheduledTasks是兩個(gè)獨(dú)立類,都有各自定時(shí)任務(wù),但運(yùn)行時(shí)起Thread Name都是一樣的pool-2-thread-1,因此每個(gè)定時(shí)任務(wù)若要新啟一個(gè)線程,需要自行編寫實(shí)現(xiàn)或者配置文件。

SpringBoot定時(shí)任務(wù)默認(rèn)單線程,多線程需要自行實(shí)現(xiàn)或配置文件

6. 并行任務(wù)

有時(shí)候會(huì)碰到不同業(yè)務(wù)的定時(shí)任務(wù),這時(shí)候利用并行任務(wù)處理要妥當(dāng),采用多線程任務(wù)。只需要配置SpringBoot的配置文件:applicationContext.xml,添加如下內(nèi)容:



  
  
  
  

添加紅框中的內(nèi)容

深入淺析SpringBoot中的定時(shí)任務(wù) 

同時(shí)注意補(bǔ)充title中遺漏的網(wǎng)址。

效果如下,每個(gè)調(diào)度處理一個(gè)任務(wù),每個(gè)調(diào)度也是一個(gè)子線程:

深入淺析SpringBoot中的定時(shí)任務(wù) 

有關(guān)executor、scheduler參數(shù)的介紹見文中的34.5 The Task Namespace節(jié)。

7. 基于springboot的定時(shí)任務(wù)工程樣例

深入淺析SpringBoot中的定時(shí)任務(wù) 

8. 動(dòng)態(tài)定時(shí)任務(wù)說(shuō)明

有時(shí)候需要實(shí)現(xiàn)動(dòng)態(tài)定時(shí)任務(wù),即工程啟動(dòng)后,可以實(shí)現(xiàn)啟動(dòng)和關(guān)閉任務(wù),同時(shí)也可以設(shè)置定時(shí)計(jì)劃。

看完上述內(nèi)容,你們對(duì)深入淺析SpringBoot中的定時(shí)任務(wù)有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝大家的支持。


當(dāng)前文章:深入淺析SpringBoot中的定時(shí)任務(wù)
標(biāo)題URL:http://fisionsoft.com.cn/article/jijois.html