欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何在springboot中使用定時任務(wù)

 更新時間:2020年12月10日 09:05:19   作者:迷茫中守候  
這篇文章主要介紹了如何在springboot中使用定時任務(wù),幫助大家更好的理解和使用springboot框架,感興趣的朋友可以了解下

在日常的開發(fā)過程中經(jīng)常使用到定時任務(wù),在springMVC的開發(fā)中,經(jīng)常和quartz框架進(jìn)行集成使用,但在springboot中沒有這么做,而是使用了java的線程池來實(shí)現(xiàn)定時任務(wù)。

一、概述

 在springboot中使用定時任務(wù)非常簡單,只需要簡單的幾步即可完成。

二、詳述

在springboot中要使用定時任務(wù),首先要保證環(huán)境是springboot的,這里使用的是springboot-2.1.2.release版本。在啟動類上加@EnableScheduling注解,如下,

package com.example.demo;

import com.example.demo.properties.ApplicationPro;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.boot.context.properties.EnableConfigurationProperties;
import org.springframework.scheduling.annotation.EnableScheduling;

@SpringBootApplication
@EnableConfigurationProperties({ApplicationPro.class})
//引入開啟定時任務(wù)的注解
@EnableScheduling
public class DemoApplication {

  public static void main(String[] args) {
    SpringApplication.run(DemoApplication.class, args);
  }

}

@EnableScheduling注解的作用就是開啟對定時任務(wù)的支持,這個注解的作用是開啟定時任務(wù)的自動配置。

在使用了@EnableScheduling注解后便可以編寫具體的定時任務(wù)的job類,該job類無需繼承或?qū)崿F(xiàn)任何接口,只要是一個被spring管理的類即可。為了使spring可以管理統(tǒng)一使用@Component注解標(biāo)識。在定時任務(wù)的類中的方法上標(biāo)識@Scheduled注解便可以定時執(zhí)行該方法,@Scheduled注解上有幾種不同的屬性,看具體的該注解的定義,

fixedDelay

@Scheduled(fixedDelay=1000)/@Scheduled(fixedDelay="1000")的意思是該方法執(zhí)行完后每隔1000ms執(zhí)行一次。看具體的代碼

package com.example.demo.job;

import lombok.extern.slf4j.Slf4j;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
@Slf4j
@Component
public class SchedulFixedRelayTest {

  //@Scheduled(fixedDelay = 5000)
  public void jobTest(){

    try {
      log.info("使用fixedDelay的定時任務(wù)");
      Thread.sleep(10*1000);

    } catch (InterruptedException e) {
      e.printStackTrace();
    }

  }


}

看執(zhí)行結(jié)果,

2020-12-09 22:02:47.511 INFO 7368 --- [      main] o.s.web.context.ContextLoader      : Root WebApplicationContext: initialization completed in 940 ms
2020-12-09 22:02:47.681 INFO 7368 --- [      main] o.s.s.concurrent.ThreadPoolTaskExecutor : Initializing ExecutorService 'applicationTaskExecutor'
2020-12-09 22:02:47.782 INFO 7368 --- [      main] o.s.s.c.ThreadPoolTaskScheduler     : Initializing ExecutorService 'taskScheduler'
2020-12-09 22:02:47.802 INFO 7368 --- [  scheduling-1] c.e.demo.job.SchedulFixedRelayTest    : 使用fixedDelay的定時任務(wù)
2020-12-09 22:02:47.820 INFO 7368 --- [      main] o.s.b.w.embedded.tomcat.TomcatWebServer : Tomcat started on port(s): 8080 (http) with context path ''
2020-12-09 22:02:47.823 INFO 7368 --- [      main] com.example.demo.DemoApplication     : Started DemoApplication in 1.627 seconds (JVM running for 2.51)
2020-12-09 22:03:02.819 INFO 7368 --- [  scheduling-1] c.e.demo.job.SchedulFixedRelayTest    : 使用fixedDelay的定時任務(wù)
2020-12-09 22:03:17.834 INFO 7368 --- [  scheduling-1] c.e.demo.job.SchedulFixedRelayTest    : 使用fixedDelay的定時任務(wù)

看上面打印的執(zhí)行時間,第一次在2020-12-09 22:02:47,由于程序會睡眠10秒,也就是說回在22:02:57執(zhí)行完,那么下次執(zhí)行應(yīng)該在22:03:02,看第二次打印的時間剛好和上面的一樣,那就證明了,該配置是在方法執(zhí)行完成后每隔XX秒執(zhí)行一次。

fixedRate

@Scheduled(fixedRate=1000)/@Scheduled(fixedRate="1000")的意思是該方法執(zhí)行完后每隔1000ms執(zhí)行一次,但是如果任務(wù)執(zhí)行的時間超過了配置的時間,則在任務(wù)執(zhí)行完會再次執(zhí)行。

任務(wù)時間小于配置的時間

package com.example.demo.job;

import lombok.extern.slf4j.Slf4j;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;

@Slf4j
@Component
public class SchedulFixedRateTest {

  @Scheduled(fixedRate = 5000)
  public void jobTest(){

    try {
      log.info("使用fixedRate的定時任務(wù)");
      Thread.sleep(1*1000);

    } catch (InterruptedException e) {
      e.printStackTrace();
    }

  }


}

任務(wù)會睡眠1s也就是任務(wù)耗時1s,fixedRate配置的是每隔5s,由于任務(wù)時間小于配置的時間,所以會每隔5s執(zhí)行一次,看執(zhí)行結(jié)果,

2020-12-09 22:16:16.156 INFO 2800 --- [  scheduling-1] c.example.demo.job.SchedulFixedRateTest : 使用fixedRate的定時任務(wù)
2020-12-09 22:16:16.188 INFO 2800 --- [      main] o.s.b.w.embedded.tomcat.TomcatWebServer : Tomcat started on port(s): 8080 (http) with context path ''
2020-12-09 22:16:16.188 INFO 2800 --- [      main] com.example.demo.DemoApplication     : Started DemoApplication in 1.625 seconds (JVM running for 2.462)
2020-12-09 22:16:21.178 INFO 2800 --- [  scheduling-1] c.example.demo.job.SchedulFixedRateTest : 使用fixedRate的定時任務(wù)
2020-12-09 22:16:26.180 INFO 2800 --- [  scheduling-1] c.example.demo.job.SchedulFixedRateTest : 使用fixedRate的定時任務(wù)

看打印的任務(wù)時間都是每隔5s執(zhí)行一次。

任務(wù)時間大于配置的時間

看任務(wù)的執(zhí)行時間打印配置的時間的情況,

package com.example.demo.job;

import lombok.extern.slf4j.Slf4j;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;

@Slf4j
@Component
public class SchedulFixedRateTest {

  @Scheduled(fixedRate = 5000)
  public void jobTest(){

    try {
      log.info("使用fixedRate的定時任務(wù)");
      Thread.sleep(10*1000);

    } catch (InterruptedException e) {
      e.printStackTrace();
    }

  }


}

這里任務(wù)執(zhí)行10s,配置的時間為5s??磮?zhí)行結(jié)果,

2020-12-09 22:17:44.070 INFO 12952 --- [  scheduling-1] c.example.demo.job.SchedulFixedRateTest : 使用fixedRate的定時任務(wù)
2020-12-09 22:17:44.102 INFO 12952 --- [      main] o.s.b.w.embedded.tomcat.TomcatWebServer : Tomcat started on port(s): 8080 (http) with context path ''
2020-12-09 22:17:44.102 INFO 12952 --- [      main] com.example.demo.DemoApplication     : Started DemoApplication in 1.626 seconds (JVM running for 2.462)
2020-12-09 22:17:54.071 INFO 12952 --- [  scheduling-1] c.example.demo.job.SchedulFixedRateTest : 使用fixedRate的定時任務(wù)
2020-12-09 22:18:04.085 INFO 12952 --- [  scheduling-1] c.example.demo.job.SchedulFixedRateTest : 使用fixedRate的定時任務(wù)

從上面的結(jié)果可以看到任務(wù)是每隔10s執(zhí)行一次,由于任務(wù)耗時大于了配置的時長,所以任務(wù)執(zhí)行完以后便會進(jìn)入下次的執(zhí)行。

cron

cron表達(dá)式共7位,分別是秒、分、小時、日、月、周、年。cron表達(dá)式可以從網(wǎng)上找,如下,

https://cron.qqe2.com/

通過cron在線生成,分別設(shè)置值,如,0/5 * * * * ?  每隔5s執(zhí)行一次,

package com.example.demo.job;

import lombok.extern.slf4j.Slf4j;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;

@Slf4j
@Component
public class SchedulCronTest {

  @Scheduled(cron = "0/5 * * * * ?")
  public void jobTest(){

    try {
      log.info("使用cron的定時任務(wù)");
      Thread.sleep(10*1000);

    } catch (InterruptedException e) {
      e.printStackTrace();
    }

  }


}

每隔5s執(zhí)行一次,任務(wù)耗時10s,看下執(zhí)行結(jié)果,

2020-12-09 22:41:42.718 INFO 17828 --- [      main] com.example.demo.DemoApplication     : Started DemoApplication in 1.609 seconds (JVM running for 2.453)
2020-12-09 22:41:45.015 INFO 17828 --- [  scheduling-1] com.example.demo.job.SchedulCronTest   : 使用cron的定時任務(wù)
2020-12-09 22:42:00.004 INFO 17828 --- [  scheduling-1] com.example.demo.job.SchedulCronTest   : 使用cron的定時任務(wù)
2020-12-09 22:42:15.000 INFO 17828 --- [  scheduling-1] com.example.demo.job.SchedulCronTest   : 使用cron的定時任務(wù)

可以看到是每隔15s執(zhí)行一次,也就是如果配置的時間間隔小于任務(wù)耗時,那么在任務(wù)執(zhí)行完后的時間間隔后再執(zhí)行,在此種情況下和fixDelay的用法一致。

三、總結(jié)

本文分析了springboot中定時任務(wù)的使用,

首先,使用@EnableScheduling開啟定時任務(wù)的自動配置;

其次,任務(wù)類必須受spring管理(使用@Component、@Service等注解均可);

最后,任務(wù)方法使用@Scheduled注解標(biāo)識,該注解有3中不同的屬性配置,fixedDelay、fixedRate、cron;

以上就是如何在springboot中使用定時任務(wù)的詳細(xì)內(nèi)容,更多關(guān)于springboot中使用定時任務(wù)的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 使用maven命令安裝jar包到本地倉庫的方法步驟

    使用maven命令安裝jar包到本地倉庫的方法步驟

    這篇文章主要介紹了使用maven命令安裝jar包到本地倉庫的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • mybatis Example Criteria like 模糊查詢問題

    mybatis Example Criteria like 模糊查詢問題

    這篇文章主要介紹了mybatis Example Criteria like 模糊查詢問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • SpringBoot不讀取bootstrap.yml/properties文件問題

    SpringBoot不讀取bootstrap.yml/properties文件問題

    這篇文章主要介紹了SpringBoot不讀取bootstrap.yml/properties文件問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • Java中IO流使用FileWriter寫數(shù)據(jù)基本操作詳解

    Java中IO流使用FileWriter寫數(shù)據(jù)基本操作詳解

    這篇文章主要介紹了Java中IO流FileWriter寫數(shù)據(jù)操作,FileWriter類提供了多種寫入字符的方法,包括寫入單個字符、寫入字符數(shù)組和寫入字符串等,它還提供了一些其他的方法,如刷新緩沖區(qū)、關(guān)閉文件等,需要的朋友可以參考下
    2023-10-10
  • Java黑科技:replace首個替換一秒搞定

    Java黑科技:replace首個替換一秒搞定

    要實(shí)現(xiàn)只替換第一個匹配項,可以使用Java中的String類的replaceFirst方法,該方法接受兩個參數(shù),第一個參數(shù)是要替換的字符串或正則表達(dá)式,第二個參數(shù)是替換后的字符串,需要的朋友可以參考下
    2023-10-10
  • Spring?Data?JPA框架的核心概念與Repository接口詳解

    Spring?Data?JPA框架的核心概念與Repository接口詳解

    Spring?Data?JPA是Spring基于JPA規(guī)范的基礎(chǔ)上封裝的?套?JPA?應(yīng)?框架,可使開發(fā)者?極簡的代碼即可實(shí)現(xiàn)對數(shù)據(jù)庫的訪問和操作,本篇我們來了解Spring?Data?JPA框架的核心概念與Repository接口
    2022-04-04
  • SpringBoot通過Filter實(shí)現(xiàn)整個項目接口的SQL注入攔截詳解

    SpringBoot通過Filter實(shí)現(xiàn)整個項目接口的SQL注入攔截詳解

    這篇文章主要介紹了SpringBoot通過Filter實(shí)現(xiàn)整個項目接口的SQL注入攔截詳解,SQL注入是比較常見的網(wǎng)絡(luò)攻擊方式之一,在客戶端在向服務(wù)器發(fā)送請求的時候,sql命令通過表單提交或者url字符串拼接傳遞到后臺持久層,最終達(dá)到欺騙服務(wù)器執(zhí)行惡意的SQL命令,需要的朋友可以參考下
    2023-12-12
  • 高內(nèi)聚低耦合原則_動力節(jié)點(diǎn)Java學(xué)院整理

    高內(nèi)聚低耦合原則_動力節(jié)點(diǎn)Java學(xué)院整理

    耦合度就是某模塊(類)與其它模塊(類)之間的關(guān)聯(lián)、感知和依賴的程度,是衡量代碼獨(dú)立性的一個指標(biāo),也是軟件工程設(shè)計及編碼質(zhì)量評價的一個標(biāo)準(zhǔn)
    2017-08-08
  • SpringBoot+Apache tika實(shí)現(xiàn)文檔內(nèi)容解析的示例詳解

    SpringBoot+Apache tika實(shí)現(xiàn)文檔內(nèi)容解析的示例詳解

    Apache tika是Apache開源的一個文檔解析工具,本文主要為大家介紹了如何在springboot中引入tika的方式解析文檔,感興趣的小伙伴可以了解一下
    2023-07-07
  • Java中Thread和Runnable創(chuàng)建線程的方式對比

    Java中Thread和Runnable創(chuàng)建線程的方式對比

    本文主要介紹了Java中Thread和Runnable創(chuàng)建線程的方式對比,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07

最新評論