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

@Scheduled在springboot中的使用方式

 更新時間:2024年08月02日 10:43:05   作者:子書少卿  
這篇文章主要介紹了@Scheduled在springboot中的使用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

@Scheduled注解參數

  • cron:cron表達式,指定任務在特定時間執(zhí)行;
  • fixedDelay:表示上一次任務執(zhí)行完成后多久再次執(zhí)行,參數類型為long,單位ms;
  • fixedDelayString:與fixedDelay含義一樣,只是參數類型變?yōu)镾tring;
  • fixedRate:表示按一定的頻率執(zhí)行任務,參數類型為long,單位ms;
  • fixedRateString: 與fixedRate的含義一樣,只是將參數類型變?yōu)镾tring;
  • initialDelay:表示延遲多久再第一次執(zhí)行任務,參數類型為long,單位ms;
  • initialDelayString:與initialDelay的含義一樣,只是將參數類型變?yōu)镾tring;
  • zone:時區(qū),默認為當前時區(qū)。

cron表達式語法

[秒] [分] [小時] [日] [月] [周] [年]

序號說明必填允許填寫的值允許的通配符
10-59, - * /
20-59, - * /
30-23, - * /
41-31, - * ? / L W
51-12 / JAN-DEC, - * /
61-7 or SUN-SAT, - * ? / L #
71970-2099, - * /

通配符說明:

  • * 表示所有值。 例如:在分的字段上設置 *,表示每一分鐘都會觸發(fā)。
  • ? 表示不指定值。使用的場景為不需要關心當前設置這個字段的值。例如:要在每月的10號觸發(fā)一個操作,但不關心是周幾,所以需要周位置的那個字段設置為”?” 具體設置為 0 0 0 10 * ?
  • - 表示區(qū)間。例如 在小時上設置 “10-12”,表示 10,11,12點都會觸發(fā)。
  • , 表示指定多個值,例如在周字段上設置 “MON,WED,FRI” 表示周一,周三和周五觸發(fā)
  • / 用于遞增觸發(fā)。如在秒上面設置”5/15” 表示從5秒開始,每增15秒觸發(fā)(5,20,35,50)。 在日字段上設置’1/3’所示每月1號開始,每隔三天觸發(fā)一次。(/后邊的參數如果循環(huán)到下一個循環(huán)是不會執(zhí)行的,只會在當前循環(huán)中去循環(huán),如:1/58->會在1、59秒執(zhí)行,但1/59->則只會在1秒的時候執(zhí)行,不會跳到下一個循環(huán)去執(zhí)行的)
  • L 表示最后的意思。在日字段設置上,表示當月的最后一天(依據當前月份,如果是二月還會依據是否是潤年[leap]), 在周字段上表示星期六,相當于”7”或”SAT”。如果在”L”前加上數字,則表示該數據的最后一個。例如在周字段上設置”6L”這樣的格式,則表示“本月最后一個星期五”
  • W 表示離指定日期的最近那個工作日(周一至周五). 例如在日字段上置”15W”,表示離每月15號最近的那個工作日觸發(fā)。如果15號正好是周六,則找最近的周五(14號)觸發(fā), 如果15號是周未,則找最近的下周一(16號)觸發(fā).如果15號正好在工作日(周一至周五),則就在該天觸發(fā)。如果指定格式為 “1W”,它則表示每月1號往后最近的工作日觸發(fā)。如果1號正是周六,則將在3號下周一觸發(fā)。(注,”W”前只能設置具體的數字,不允許區(qū)間”-“)。
  • # 序號(表示每月的第幾個周幾),例如在周字段上設置”6#3”表示在每月的第三個周六.注意如果指定”#5”,正好第五周沒有周六,則不會觸發(fā)該配置(用在母親節(jié)和父親節(jié)再合適不過了) ;小提示:’L’和 ‘W’可以一組合使用。如果在日字段上設置”LW”,則表示在本月的最后一個工作日觸發(fā);周字段的設置,若使用英文字母是不區(qū)分大小寫的,即MON與mon相同。

1. 示例

  • 每隔5秒執(zhí)行一次:*/5 * * * * ?
  • 每隔1分鐘執(zhí)行一次:0 */1 * * * ?
  • 每天23點執(zhí)行一次:0 0 23 * * ?
  • 每天凌晨1點執(zhí)行一次:0 0 1 * * ?
  • 每月1號凌晨1點執(zhí)行一次:0 0 1 1 * ?
  • 每月最后一天23點執(zhí)行一次:0 0 23 L * ?
  • 每周星期六凌晨1點實行一次:0 0 1 ? * L
  • 在26分、29分、33分執(zhí)行一次:0 26,29,33 * * * ?
  • 每天的0點、13點、18點、21點都執(zhí)行一次:0 0 0,13,18,21 * * ?

2. zone

時區(qū),接收一個java.util.TimeZone#ID。

cron表達式會基于該時區(qū)解析。

默認是一個空字符串,即取服務器所在地的時區(qū)。

比如我們一般使用的時區(qū)Asia/Shanghai。該字段我們一般留空。

3. fixedDelay

上一次執(zhí)行完畢時間點之后多長時間再執(zhí)行。

如:

@Scheduled(fixedDelay = 5000) //上一次執(zhí)行完畢時間點之后5秒再執(zhí)行

4. fixedDelayString

3.fixedDelay 意思相同,只是使用字符串的形式。

唯一不同的是支持占位符。

如:

@Scheduled(fixedDelayString = "5000") //上一次執(zhí)行完畢時間點之后5秒再執(zhí)行

占位符的使用(配置文件中有配置:time.fixedDelay=5000):

    @Scheduled(fixedDelayString = "${time.fixedDelay}")
    void testFixedDelayString() {
        System.out.println("Execute at " + System.currentTimeMillis());
    }

運行結果:

占位符的使用

5. fixedRate

上一次開始執(zhí)行時間點之后多長時間再執(zhí)行。

如:

@Scheduled(fixedRate = 5000) //上一次開始執(zhí)行時間點之后5秒再執(zhí)行

6. fixedRateString

5.fixedRate 意思相同,只是使用字符串的形式。

唯一不同的是支持占位符。

7. initialDelay

第一次延遲多長時間后再執(zhí)行。

如:

@Scheduled(initialDelay=1000, fixedRate=5000) //第一次延遲1秒后執(zhí)行,之后按fixedRate的規(guī)則每5秒執(zhí)行一次

8. initialDelayString

7.initialDelay 意思相同,只是使用字符串的形式。唯一不同的是支持占位符。

That's all ! Thanks for reading.

另外如果要想@Scheduled注解生效需要添加配置

package com.example.demo;

import lombok.extern.slf4j.Slf4j;
import org.springframework.aop.interceptor.AsyncUncaughtExceptionHandler;
import org.springframework.aop.interceptor.SimpleAsyncUncaughtExceptionHandler;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.scheduling.TaskScheduler;
import org.springframework.scheduling.annotation.AsyncConfigurer;
import org.springframework.scheduling.annotation.EnableAsync;
import org.springframework.scheduling.annotation.EnableScheduling;
import org.springframework.scheduling.annotation.SchedulingConfigurer;
import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;
import org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler;
import org.springframework.scheduling.config.ScheduledTaskRegistrar;

import java.util.concurrent.Executor;
import java.util.concurrent.Executors;
import java.util.concurrent.ThreadPoolExecutor;


/**
 * 在用springboot框架做定時任務的時候,大部分情況都是直接通過@Scheduled注解來指定定時任務的。
 * 但是當你有多個定時任務時,@Scheduled并不一定會按時執(zhí)行。
 * 因為使用@Scheduled的定時任務雖然是異步執(zhí)行的,但是,默認不同的定時任務之間并不是并行的。
 *
 * 當未手動指定taskScheduler時,會通過Executors.newSingleThreadScheduledExecutor()創(chuàng)建默認的單線程線程池,
 * 且該線程池的拒絕策略為AbortPolicy,這種策略在線程池無可用線程時丟棄任務,
 * 并拋出異常RejectedExecutionException。
 *
 */
@Slf4j
@Configuration
@EnableScheduling
@EnableAsync
public class ScheduledConfig implements
        SchedulingConfigurer
//        , AsyncConfigurer
{


    /**
     * ThreadPoolTaskExecutor是一個專門用于執(zhí)行任務的類。
     * ThreadPoolTaskScheduler是一個專門用于調度任務的類。
     * 一個ThreadPoolTaskExecutor通過它的corePoolSize , maxPoolSize , keepAliveSeconds和queueCapacity屬性在線程池中提供細粒度的配置。
     * 諸如ThreadPoolTaskScheduler這樣的調度器不提供這樣的配置。
     */


    /** 最大線程數 */
    private static final int maxPoolSize = 10;
    /** 線程池名前綴(字符串有長度限制) */
    private static final String threadNamePrefix = "yu-scheduled-";

    @Bean("asyncExecutorScheduled") // bean的名稱,默認為首字母小寫的方法名,如果不聲明則會使用方法名
    public ThreadPoolTaskScheduler asyncExecutorScheduled(){
        ThreadPoolTaskScheduler executor = new ThreadPoolTaskScheduler();
        executor.setPoolSize(maxPoolSize);
        executor.setThreadNamePrefix(threadNamePrefix);
        executor.setAwaitTerminationSeconds(60);
        executor.setWaitForTasksToCompleteOnShutdown(true);
        // 初始化
        executor.initialize();
        return executor;
    }

    @Override
    public void configureTasks(ScheduledTaskRegistrar taskRegistrar) {
        taskRegistrar.setTaskScheduler(this.asyncExecutorScheduled());
    }

//    /**
//     * 處理異步方法調用時要使用的實例
//     * @return
//     */
//    @Override
//    public Executor getAsyncExecutor() {
//        return this.asyncExecutorScheduled();
//    }
//
//    /**
//     * 在使用void返回類型的異步方法執(zhí)行期間拋出異常時要使用的實例。
//     * @return
//     */
//    @Override
//    public AsyncUncaughtExceptionHandler getAsyncUncaughtExceptionHandler() {
//        return new SimpleAsyncUncaughtExceptionHandler();
//    }
}

或者:

package com.example.demo;

import lombok.extern.slf4j.Slf4j;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.scheduling.annotation.EnableScheduling;

import java.util.concurrent.ScheduledThreadPoolExecutor;


/**
 * scheduled 配置文件的第二種使用  不建議使用
 */
@Slf4j
@Configuration
@EnableScheduling
public class ScheduledConfig2 {



    @Bean
    public ScheduledThreadPoolExecutor scheduledExecutorService() {
        ScheduledThreadPoolExecutor executor = new ScheduledThreadPoolExecutor(10);
        return executor;
    }


}

實例:

package com.example.demo.service;

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

import java.util.Date;

/**
 * @Scehduled 定時任務測試
 */
@Slf4j
@Service
public class ScheduledService {
    /**5
     *測試
     */
    @Scheduled(cron = "*/5 * * * * *")
    public void testScheduled1(){
        log.info("定時1:{}",new Date());
    }

    @Scheduled(cron = "*/5 * * * * *")
    public void testScheduled2(){
        log.info("定時2:{}",new Date());
    }

}

結果:

2020-05-25 16:36:00.001  INFO 9116 --- [ yu-scheduled-1] c.example.demo.service.ScheduledService  : 定時2:Mon May 25 16:36:00 CST 2020
2020-05-25 16:36:00.005  INFO 9116 --- [ yu-scheduled-2] c.example.demo.service.ScheduledService  : 定時1:Mon May 25 16:36:00 CST 2020
2020-05-25 16:36:05.004  INFO 9116 --- [ yu-scheduled-1] c.example.demo.service.ScheduledService  : 定時2:Mon May 25 16:36:05 CST 2020
2020-05-25 16:36:05.004  INFO 9116 --- [ yu-scheduled-2] c.example.demo.service.ScheduledService  : 定時1:Mon May 25 16:36:05 CST 2020

總結

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • springboot?使用websocket技術主動給前端發(fā)送消息的實現(xiàn)

    springboot?使用websocket技術主動給前端發(fā)送消息的實現(xiàn)

    這篇文章主要介紹了springboot?使用websocket技術主動給前端發(fā)送消息的實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • java實現(xiàn)簡易聊天功能

    java實現(xiàn)簡易聊天功能

    這篇文章主要為大家詳細介紹了java實現(xiàn)簡易聊天功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-09-09
  • 深入介紹Spring框架及故障排除

    深入介紹Spring框架及故障排除

    這篇文章主要介紹了深入介紹Spring框架及故障排除,文章圍繞主題展開詳細的內容介紹,具有一定的參考價值,感興趣的小伙伴可以參考一下
    2022-06-06
  • 深入探究Bean生命周期的擴展點Bean Post Processor

    深入探究Bean生命周期的擴展點Bean Post Processor

    在Spring框架中,Bean生命周期的管理是非常重要的一部分,在Bean的創(chuàng)建、初始化和銷毀過程中,Spring提供了一系列的擴展點,其中,Bean Post Processor(后處理器)是一個重要的擴展點,它能夠在Bean的初始化前后做一些額外的處理,本文就和大家一起深入探究
    2023-07-07
  • Intellj?idea新建的java源文件夾不是藍色的圖文解決辦法

    Intellj?idea新建的java源文件夾不是藍色的圖文解決辦法

    idea打開java項目后新建的模塊中,java文件夾需要變成藍色,這篇文章主要給大家介紹了關于Intellj?idea新建的java源文件夾不是藍色的相關資料,文中通過圖文介紹的非常詳細,需要的朋友可以參考下
    2024-02-02
  • Java多線程的同步優(yōu)化的6種方案

    Java多線程的同步優(yōu)化的6種方案

    大家使用多線程無非是為了提高性能,在Java中,有多線程并發(fā)時,我們可以使用多線程同步的方式來解決內存一致性的問題。本文就詳細的介紹了Java多線程同步優(yōu)化,感興趣的可以了解一下
    2021-05-05
  • Tomcat多war包部署實戰(zhàn)示例及注意事項

    Tomcat多war包部署實戰(zhàn)示例及注意事項

    多服務部署在一個tomcat中,服務之間互相調用,下面這篇文章主要給大家介紹了關于Tomcat多war包部署實戰(zhàn)示例及注意事項的相關資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2023-12-12
  • Java無需解壓直接讀取ZIP壓縮包里的文件及內容

    Java無需解壓直接讀取ZIP壓縮包里的文件及內容

    最近開發(fā)的時候遇到要獲取到zip壓縮包里面的文件內容,解決方案就是通過ZipInputStream來讀取,下面通過實例代碼介紹Java無需解壓直接讀取ZIP壓縮包里的文件及內容,感興趣的朋友跟隨小編一起看看吧
    2024-03-03
  • SpringBoot實現(xiàn)單文件與多文件上傳功能

    SpringBoot實現(xiàn)單文件與多文件上傳功能

    這篇文章主要介紹了SpringBoot實現(xiàn)單文件與多文件上傳功能,Spring?MVC對文件上傳做了簡化,而在Spring?Boot中對此做了更進一步的簡化,文件上傳變得更為方便,下面開始演示,需要的小伙伴可以參考一下,希望對你有所幫助
    2022-01-01
  • Java開發(fā)之內部類對象的創(chuàng)建及hook機制分析

    Java開發(fā)之內部類對象的創(chuàng)建及hook機制分析

    這篇文章主要介紹了Java開發(fā)之內部類對象的創(chuàng)建及hook機制,結合實例形式分析了java基于hook機制內部類對象的創(chuàng)建與使用,需要的朋友可以參考下
    2018-01-01

最新評論