0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

說(shuō)說(shuō)Spring定時(shí)任務(wù)如何大規(guī)模企業(yè)級(jí)運(yùn)用

OSC開源社區(qū) ? 來(lái)源:阿里云云原生 ? 作者:姚輝(千習(xí)) ? 2022-11-04 09:36 ? 次閱讀

Spring 定時(shí)任務(wù)簡(jiǎn)介

Cloud Native

定時(shí)任務(wù)是業(yè)務(wù)應(yīng)用開發(fā)中非常普遍存在的場(chǎng)景(如:每分鐘掃描超時(shí)支付的訂單,每小時(shí)清理一次數(shù)據(jù)庫(kù)歷史數(shù)據(jù),每天統(tǒng)計(jì)前一天的數(shù)據(jù)并生成報(bào)表等等),解決方案很多,Spring 框架提供了一種通過(guò)注解來(lái)配置定時(shí)任務(wù)的解決方案,接入非常的簡(jiǎn)單,僅需如下兩步:

1. 在啟動(dòng)類上添加注解@EnableScheduling


@SpringBootApplication
@EnableScheduling  // 添加定時(shí)任務(wù)啟動(dòng)注解
public class SpringSchedulerApplication {
    public static void main(String[] args) {
        SpringApplication.run(SpringSchedulerApplication.class, args);
    }
}
2. 開發(fā)定時(shí)任務(wù) Bean 并配置相應(yīng)的定時(shí)注解@Scheduled

@Component
public class SpringScheduledProcessor {


  /**
     * 通過(guò)Cron表達(dá)式指定頻率或指定時(shí)間
     */
    @Scheduled(cron = "0/5 * * * * ?")
    public void doSomethingByCron() {
        System.out.println("do something");
    }
    
  /**
     * 固定執(zhí)行間隔時(shí)間
     */
    @Scheduled(fixedDelay = 2000)
    public void doSomethingByFixedDelay() {
        System.out.println("do something");
    }


    /**
     * 固定執(zhí)行觸發(fā)頻率
     */
    @Scheduled(fixedRate = 2000)
    public void doSomethingByFixedRate() {
        System.out.println("do something");
    } 
}

Spring 定時(shí)任務(wù)原理

Cloud Native

運(yùn)行原理

Spring 定時(shí)任務(wù)核心邏輯主要在 spring-context 中的 scheduling 包中,其主要結(jié)構(gòu)包括:

定時(shí)任務(wù)解析:通過(guò) ScheduledTasksBeanDefinitionParser 對(duì) XML 定義任務(wù)配置解析;也可通過(guò) ScheduledAnnotationBeanPostProcessor對(duì)@Scheduled 注解進(jìn)行任務(wù)解析(常見模式)。

定時(shí)任務(wù)注冊(cè)登記:上述解析獲得的 Task 任務(wù)配置會(huì)被注冊(cè)登記至 ScheduledTaskRegistrar 中以備運(yùn)行使用。

任務(wù)定時(shí)運(yùn)行:完成所有任務(wù)注冊(cè)登記后,會(huì)通過(guò) TaskScheduler 正式地定時(shí)運(yùn)行相關(guān)任務(wù),底層通過(guò) JDK 的 ScheduledExecutorService 運(yùn)行任務(wù)。

a6912d5a-5b87-11ed-a3b6-dac502259ad0.jpg

業(yè)務(wù)邏輯會(huì)將被包裝在 ScheduledMethodRunnable 類中,其中包含了待執(zhí)行的目標(biāo)業(yè)務(wù)對(duì)象 Bean 和業(yè)務(wù)方法,該 Runnable 對(duì)象在運(yùn)行時(shí)會(huì)被提交至 ScheduledExecutorService 調(diào)度線程池完成任務(wù)的定時(shí)運(yùn)行。

a6a9892c-5b87-11ed-a3b6-dac502259ad0.jpg

從上圖可以看到真正要運(yùn)行的業(yè)務(wù)邏輯 ScheduledMethodRunnable 會(huì)被 ReschedulingRunnable、DelegatingErrorHandlingRunnable 做了代理擴(kuò)展,這兩層代理擴(kuò)展具有如下意義:

DelegatingErrorHandlingRunnable:為業(yè)務(wù)方法運(yùn)行異常進(jìn)行包裝處理,提供了自定義異常處理機(jī)制、解決 JDK 原生定時(shí)任務(wù)執(zhí)行異常后任務(wù)失效問(wèn)題。

ReschedulingRunnable:提供了擴(kuò)展的定時(shí)模式支持,可支持基于 Trigger 接口自定義實(shí)現(xiàn)獲取下次觸發(fā)時(shí)間定時(shí)調(diào)度,默認(rèn)提供的 Cron 定時(shí)通過(guò)此方式進(jìn)行擴(kuò)展實(shí)現(xiàn)。

定時(shí)模式

Spring 定時(shí)任務(wù) Task 類的模式主要可分為兩類:IntervalTask 和 TriggerTask。前者表示固定頻率間隔執(zhí)行,后者則采用 Trigger 觸發(fā)器模式實(shí)現(xiàn)定時(shí)調(diào)度,Cron 表達(dá)式配置為該模式實(shí)現(xiàn)。

FixedDelay:按固定延遲頻率執(zhí)行,任務(wù)下一次觸發(fā)時(shí)間=上一次執(zhí)行結(jié)束時(shí)間+Delay 延遲時(shí)間。

a6c1e63e-5b87-11ed-a3b6-dac502259ad0.jpg

FixedRate:按固定頻率觸發(fā)執(zhí)行,任務(wù)下一次觸發(fā)時(shí)間=上一次觸發(fā)時(shí)間+Delay 延遲時(shí)間。如果上一次執(zhí)行方法不結(jié)束會(huì)阻塞下一次任務(wù)執(zhí)行。

a6d5c654-5b87-11ed-a3b6-dac502259ad0.jpg

Cron 表達(dá)式:按 Cron 表達(dá)式計(jì)算下一次觸發(fā)時(shí)間,任務(wù)下一次觸發(fā)時(shí)間=cron(上一次執(zhí)行結(jié)束時(shí)間)。

進(jìn)階擴(kuò)展

線程池運(yùn)行

默認(rèn)配置下底層運(yùn)行的線程池為單線程,單線程的運(yùn)行模型在任務(wù)量較多且觸發(fā)頻率較高的情況下,一旦某個(gè)任務(wù)發(fā)生阻塞會(huì)導(dǎo)致所有后續(xù)定時(shí)任務(wù)運(yùn)行阻斷,這對(duì)業(yè)務(wù)運(yùn)行帶來(lái)嚴(yán)重隱患。常見可采用如下方式:

配置定時(shí)執(zhí)行線程池:常見基于配置 Spring Boot 配置(spring.task.scheduling.pool.size=線程數(shù)),線程數(shù)大小取決于任務(wù)數(shù)及調(diào)度頻率合理配置。

配置異步任務(wù):在 spring context 中的 scheduling 模塊下提供了@EnableAsync 和@Async,可用于開啟任務(wù)異步執(zhí)行,實(shí)現(xiàn)定時(shí)調(diào)度線程池非阻塞運(yùn)行。該模式下存在一些不足之處:異常處理需要走異步調(diào)用的 AsyncUncaughtExceptionHandler 異常處理接口實(shí)現(xiàn),同步/異步定時(shí)任務(wù)異常處理機(jī)制不統(tǒng)一,另外異步模式增加了業(yè)務(wù)應(yīng)用的線程開銷。


@Scheduled(fixedDelay = 2000)
@Async
public void test() {
    System.out.println(DateUtil.now()+ " test.");
}

異常統(tǒng)一處理

定時(shí)任務(wù)運(yùn)行可設(shè)置統(tǒng)一異常處理,基于 ErrorHandler 接口開發(fā)對(duì)應(yīng)異常處理實(shí)現(xiàn)類。對(duì)應(yīng)的異常實(shí)現(xiàn)處理類需要注入到核心的 ThreadPoolTaskScheduler 中,用戶可以通過(guò)自定義 TaskSchedulerCustomizer 方式來(lái)實(shí)現(xiàn) ErrorHandler 自定義異常處理 Bean 注入至 ThreadPoolTaskScheduler 中。


@Component
public class DemoTaskSchedulerCustomizer implements TaskSchedulerCustomizer {
    @Override
    public void customize(ThreadPoolTaskScheduler taskScheduler) {
        taskScheduler.setErrorHandler(new DemoErrorHandler());
    }


    private class DemoErrorHandler implements ErrorHandler {
        @Override
        public void handleError(Throwable throwable) {
            System.out.println("異常統(tǒng)一處理.");
        }
    }
}

原生 Spring 定時(shí)任務(wù)在企業(yè)中遇到的問(wèn)題

Cloud Native

任務(wù)重復(fù)執(zhí)行

Spring 定時(shí)任務(wù),只要有注解就會(huì)執(zhí)行,在分布式場(chǎng)景下,所有機(jī)器代碼一致,會(huì)導(dǎo)致同一個(gè)任務(wù)在多臺(tái)機(jī)器上重復(fù)執(zhí)行。一般的解決方案是搶鎖觸發(fā),分布式鎖實(shí)現(xiàn)形式可采用 DB、ZK、Redis 等方式。

a6f6147c-5b87-11ed-a3b6-dac502259ad0.jpg

示例代碼如下:


@Component
@EnableScheduling
public class MyTask {
    /**
     * 每分鐘的第30秒跑一次
     */
    @Scheduled(cron = "30 * * * * ?")
    public void task1() throws Exception {
        String lockName = "task1";
        if (tryLock(lockName)) {
            System.out.println("hello cron");
            releaseLock(lockName);
        } else {
            return;
        }
    }
    private boolean tryLock(String lockName) {
        //TODO
        return true;
    }
    
    private void releaseLock(String lockName) {
        //TODO
    }
}
如上圖所示,當(dāng)任務(wù)觸發(fā)時(shí) 3 個(gè) server 會(huì)對(duì)任務(wù)搶鎖,僅獲得任務(wù)鎖的 server 才能執(zhí)行對(duì)應(yīng)任務(wù)業(yè)務(wù)邏輯。當(dāng)前的這個(gè)設(shè)計(jì),仔細(xì)一點(diǎn)的同學(xué)可以發(fā)現(xiàn),其實(shí)還是有可能導(dǎo)致任務(wù)重復(fù)執(zhí)行的。比如任務(wù)執(zhí)行的非???,A 這臺(tái)機(jī)器搶到鎖,執(zhí)行完任務(wù)后很快就釋放鎖了。B 這臺(tái)機(jī)器后搶鎖,還是會(huì)搶到鎖,再執(zhí)行一遍任務(wù)。

無(wú)管控?zé)o運(yùn)維

原生 Spring 定時(shí)任務(wù)沒有控制臺(tái),無(wú)法動(dòng)態(tài)的新增和修改定時(shí)任務(wù),如果要修改定時(shí)任務(wù)的配置(比如每分鐘跑一次改成每小時(shí)跑一次),必須修改代碼重新發(fā)布應(yīng)用。同時(shí)原生Spring定時(shí)任務(wù)也沒有運(yùn)維操作,不支持運(yùn)行一次任務(wù),任務(wù)失敗了也不支持重跑任務(wù)。

如果要自研的可視化控制臺(tái)來(lái)實(shí)現(xiàn)整套任務(wù)可視化管控體系,需要一定的前后端研發(fā)成本和服務(wù)部署成本投入。對(duì)于需要自建的用戶而言,可參考以下需求功能進(jìn)行自有平臺(tái)建設(shè):

任務(wù)的可視化動(dòng)態(tài)配置

任務(wù)執(zhí)行運(yùn)行詳細(xì)信息的可視化查看

任務(wù)執(zhí)行日志、執(zhí)行調(diào)用鏈、調(diào)度觸發(fā)的可視化查詢分析

業(yè)務(wù)應(yīng)用間任務(wù)信息配置權(quán)限隔離

無(wú)業(yè)務(wù)失敗通知能力

對(duì)于完整企業(yè)級(jí)定時(shí)任務(wù)運(yùn)用方案中,報(bào)警通知能力必不可少,任務(wù)跑失敗了需要及時(shí)通知到用戶,否則可能產(chǎn)生故障。

原生 Spring 定時(shí)任務(wù)不支持報(bào)警通知能力,如果要自研,可以參考上一章節(jié)中《異常統(tǒng)一處理》對(duì)任務(wù)失敗的信息進(jìn)行收集,構(gòu)建相應(yīng)的異常處理機(jī)制(包括對(duì)接各類報(bào)警平臺(tái)進(jìn)行異常消息通知處理,定義異常等級(jí)和類別進(jìn)行不同的通知策略),然后進(jìn)行定時(shí)任務(wù)報(bào)警通知。

a70ba49a-5b87-11ed-a3b6-dac502259ad0.jpg

無(wú)在線排查分析能力

定時(shí)任務(wù)在運(yùn)行過(guò)程中會(huì)存在各種各樣的問(wèn)題,比如:執(zhí)行失敗、執(zhí)行耗時(shí)、執(zhí)行卡住等,這些都需要在后期實(shí)際運(yùn)維去定位快速分析。在對(duì)應(yīng)分析過(guò)程中沒有高效在線排查能力的話將遇到很多棘手的問(wèn)題:

集群中任務(wù)對(duì)應(yīng)時(shí)間點(diǎn)是跑在哪個(gè)機(jī)器上無(wú)從可知

需要在大量的業(yè)務(wù)應(yīng)用日志中去檢索對(duì)應(yīng)時(shí)點(diǎn)的定時(shí)任務(wù)執(zhí)行日志,需要自行對(duì)接日志服務(wù)改善

如果任務(wù)涉及多個(gè)跨服務(wù)調(diào)用,無(wú)法定位執(zhí)行異常點(diǎn)或執(zhí)行耗時(shí)點(diǎn),需要自建全鏈路追蹤來(lái)支持

阿里云 Spring 定時(shí)任務(wù)企業(yè)級(jí)解決方案

Cloud Native

接下來(lái)主要講下如何利用公有云上任務(wù)調(diào)度 SchedulerX 輕松接入基于 Spring 開發(fā)的定時(shí)任務(wù)。前面聊了基于 Spring 原生功能在使用過(guò)程中面臨的問(wèn)題及需要自行處理解決的相關(guān)方案,可以看到僅針對(duì)企業(yè)級(jí)最基礎(chǔ)的運(yùn)用場(chǎng)景下就需要花費(fèi)較多的改造投入及相關(guān)服務(wù)后續(xù)運(yùn)維投入。通過(guò)接入 SchedulerX 任務(wù)調(diào)度平臺(tái),原本 Spring 定時(shí)任務(wù)使用者可無(wú)縫且 0 改造獲得企業(yè)級(jí)運(yùn)用所需能力,同時(shí)降低了自研部署運(yùn)維定時(shí)服務(wù)相關(guān)組件的技術(shù)成本。

如何接入

對(duì)于 SchedulerX 新用戶而言接入僅需三步(參考附件接入手冊(cè)):

依賴 SchedulerX 的 Spring Boot 版 SDK 完成調(diào)度平臺(tái)接入(版本>=1.7.2,老用戶僅升級(jí) SDK 版本即可)

配置文件添加配置項(xiàng),配置開啟后 Spring 定時(shí)調(diào)度器將不運(yùn)行相關(guān)任務(wù)(未配置情況下,不會(huì)主動(dòng)接管原 Spring 定時(shí)任務(wù)運(yùn)行,在配置開啟前不會(huì)影響原本定時(shí)任務(wù)業(yè)務(wù)運(yùn)行)


# 配置表示由SchedulerX接管Spring定時(shí)任務(wù)運(yùn)行
spring.schedulerx2.task.scheduling.scheduler=schedulerx

控制臺(tái)上在對(duì)應(yīng)應(yīng)用分組下創(chuàng)建任務(wù)配置定時(shí)觸發(fā)。也可以選擇開啟自動(dòng)同步任務(wù)配置方式(可選)


# 自動(dòng)同步Spring定時(shí)任務(wù)至調(diào)度平臺(tái),無(wú)需單獨(dú)手動(dòng)創(chuàng)建(默認(rèn)不開啟)
spring.schedulerx2.task.scheduling.sync=true

接入優(yōu)勢(shì)

白屏管控和運(yùn)維

提供白屏控制臺(tái)可以動(dòng)態(tài)新增、修改、啟用、禁用任務(wù),支持運(yùn)行一次、原地重跑、重刷數(shù)據(jù)、停止任務(wù)、標(biāo)記成功等運(yùn)維操作。 a7287b56-5b87-11ed-a3b6-dac502259ad0.pnga7406996-5b87-11ed-a3b6-dac502259ad0.pnga75ad128-5b87-11ed-a3b6-dac502259ad0.png

可視化在線排查問(wèn)題

支持執(zhí)行記錄查看、執(zhí)行業(yè)務(wù)日志查詢、執(zhí)行全鏈路追蹤。
a772929a-5b87-11ed-a3b6-dac502259ad0.pnga78a0f42-5b87-11ed-a3b6-dac502259ad0.png

豐富的報(bào)警通知

SchedulerX 提供豐富的報(bào)警通知能力,支持短信、電話、郵件、webhook 報(bào)警,支持報(bào)警聯(lián)系人組和報(bào)警歷史,可白屏動(dòng)態(tài)配置。 a79fd7d2-5b87-11ed-a3b6-dac502259ad0.pnga7df0cc2-5b87-11ed-a3b6-dac502259ad0.png

其他優(yōu)勢(shì)

無(wú)改造成本的平臺(tái)接入方案。

無(wú)需額外獨(dú)立運(yùn)維調(diào)度服務(wù)平臺(tái)或其他第三方組件服務(wù)。

任務(wù)運(yùn)行在集群環(huán)境中具備穩(wěn)定高可靠支持,規(guī)避了原生框架存在的重復(fù)執(zhí)行問(wèn)題,具備故障自動(dòng)轉(zhuǎn)移能力。

在企業(yè)內(nèi)多個(gè)團(tuán)隊(duì)可共享一套平臺(tái)使用,通過(guò)命名空間和應(yīng)用分組實(shí)現(xiàn)各團(tuán)隊(duì)任務(wù)配置數(shù)據(jù)隔離及環(huán)境隔離。

總結(jié)

Cloud Native

本文主要從 Spring 定時(shí)任務(wù)的運(yùn)行機(jī)制進(jìn)行剖析闡述,并對(duì)如何擴(kuò)展框架原生能力以滿足企業(yè)級(jí)生產(chǎn)環(huán)境運(yùn)行定時(shí)任務(wù)所需各種場(chǎng)景提出了相應(yīng)的建議,用戶可作參考構(gòu)建自己內(nèi)部定時(shí)任務(wù)方案。同時(shí)就阿里云上提供的任務(wù)調(diào)度服務(wù)如何接入 Spring 定時(shí)任務(wù)的運(yùn)行進(jìn)行講解,并簡(jiǎn)單展示了接入后所帶來(lái)的企業(yè)級(jí)能力。最后歡迎有定時(shí)任務(wù)業(yè)務(wù)需求用戶可先通過(guò)基礎(chǔ)免費(fèi)額度體驗(yàn)感受云上服務(wù)帶來(lái)便捷。

審核編輯:湯梓紅

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • spring
    +關(guān)注

    關(guān)注

    0

    文章

    340

    瀏覽量

    14343

原文標(biāo)題:說(shuō)說(shuō)Spring定時(shí)任務(wù)如何大規(guī)模企業(yè)級(jí)運(yùn)用

文章出處:【微信號(hào):OSC開源社區(qū),微信公眾號(hào):OSC開源社區(qū)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    SAS走進(jìn)企業(yè)級(jí)存儲(chǔ)應(yīng)用

    SAS走進(jìn)企業(yè)級(jí)存儲(chǔ)應(yīng)用串行SCSI(SAS)的出現(xiàn)已經(jīng)有幾年了。2005年,在主要的接口技術(shù)中,由于OEM服務(wù)器制造商和系統(tǒng)集成商開始提供串行SCSI解決方案,企業(yè)級(jí)存儲(chǔ)市場(chǎng)將會(huì)顯現(xiàn)革命性的進(jìn)展
    發(fā)表于 11-13 21:58

    關(guān)于stm32系統(tǒng)定時(shí)任務(wù)的問(wèn)題

    在用stm32做一個(gè)飛控程序時(shí)。需要用到上面這種系統(tǒng)循環(huán)定時(shí)任務(wù),有一個(gè)問(wèn)題:在System_Task_Loop函數(shù)里面,有1ms 、2ms、5ms的循環(huán)任務(wù),但是他的這些定時(shí)是怎么得到的?是隨便
    發(fā)表于 10-10 23:43

    Linux系統(tǒng)定時(shí)任務(wù)Crond

    會(huì)定期(默認(rèn)每分鐘檢查一次)檢查系統(tǒng)中是否有要執(zhí)行的任務(wù)工作,如果有,便會(huì)根據(jù)其預(yù)先設(shè)定的定時(shí)任務(wù)規(guī)則自動(dòng)執(zhí)行該定時(shí)任務(wù)工作,這個(gè)crond定時(shí)任務(wù)服務(wù)就相當(dāng)于我們平時(shí)早起使用的鬧鐘一
    發(fā)表于 07-05 06:22

    linux的循環(huán)定時(shí)任務(wù)

    linux循環(huán)定時(shí)任務(wù)
    發(fā)表于 05-20 14:59

    定時(shí)任務(wù)的發(fā)展史是怎么樣的

    定時(shí)任務(wù)是互聯(lián)網(wǎng)行業(yè)里最常用的服務(wù)之一,本文給大家介紹定時(shí)任務(wù)在我司的發(fā)展歷程。 linux系統(tǒng)中一般使用crontab命令來(lái)實(shí)現(xiàn),在Java世界里,使用最廣泛的就是quartz了。我司
    發(fā)表于 07-18 17:38 ?0次下載
    <b class='flag-5'>定時(shí)任務(wù)</b>的發(fā)展史是怎么樣的

    SpringBoot如何實(shí)現(xiàn)動(dòng)態(tài)增刪啟停定時(shí)任務(wù)

    spring boot項(xiàng)目中,可以通過(guò) @EnableScheduling 注解和@Scheduled注解實(shí)現(xiàn)定時(shí)任務(wù),也可以通過(guò)SchedulingConfigurer接口來(lái)實(shí)現(xiàn)定時(shí)任務(wù)。但是
    的頭像 發(fā)表于 09-24 09:49 ?2947次閱讀
    SpringBoot如何實(shí)現(xiàn)動(dòng)態(tài)增刪啟停<b class='flag-5'>定時(shí)任務(wù)</b>

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

    在日常工作中,我們常常會(huì)用到需要周期性執(zhí)行的任務(wù),一種方式是采用 Linux 系統(tǒng)自帶的 crond 結(jié)合命令行實(shí)現(xiàn)。另外一種方式是直接使用Python。接下來(lái)整理的是常見的Python定時(shí)任務(wù)
    的頭像 發(fā)表于 10-08 15:20 ?5733次閱讀

    解析Golang定時(shí)任務(wù)庫(kù)gron設(shè)計(jì)和原理

    正巧,最近看到了 gron 這個(gè)開源項(xiàng)目,它是用 Golang 實(shí)現(xiàn)一個(gè)并發(fā)安全的定時(shí)任務(wù)庫(kù)。實(shí)現(xiàn)非常簡(jiǎn)單精巧,代碼量也不多。今天我們就來(lái)一起結(jié)合源碼看一下,怎樣基于 Golang 的能力做出來(lái)一個(gè)【定時(shí)任務(wù)庫(kù)】。
    的頭像 發(fā)表于 12-15 13:57 ?1339次閱讀

    求一種SpringBoot定時(shí)任務(wù)動(dòng)態(tài)管理通用解決方案

    SpringBoot的定時(shí)任務(wù)的加強(qiáng)工具,實(shí)現(xiàn)對(duì)SpringBoot原生的定時(shí)任務(wù)進(jìn)行動(dòng)態(tài)管理,完全兼容原生@Scheduled注解,無(wú)需對(duì)原本的定時(shí)任務(wù)進(jìn)行修改
    的頭像 發(fā)表于 02-03 09:49 ?782次閱讀

    Spring Boot中整合兩種定時(shí)任務(wù)的方法

    Spring + SpringMVC 環(huán)境中,一般來(lái)說(shuō),要實(shí)現(xiàn)定時(shí)任務(wù),我們有兩中方案,一種是使用 Spring 自帶的定時(shí)任務(wù)處理器 @Scheduled 注解,另一種就是使用第
    的頭像 發(fā)表于 04-07 14:55 ?1550次閱讀
    <b class='flag-5'>Spring</b> Boot中整合兩種<b class='flag-5'>定時(shí)任務(wù)</b>的方法

    Spring Boot中如何使用定時(shí)任務(wù)

    本文介紹在 Spring Boot 中如何使用定時(shí)任務(wù),使用非常簡(jiǎn)單,就不做過(guò)多說(shuō)明了。
    的頭像 發(fā)表于 04-12 10:56 ?975次閱讀

    如何動(dòng)態(tài)添加修改刪除定時(shí)任務(wù)?

    如何動(dòng)態(tài)添加修改刪除定時(shí)任務(wù)?那么我們一起看看具體怎么實(shí)現(xiàn),先看下本節(jié)大綱: (1)思路說(shuō)明; (2)代碼解析; (3)修改定時(shí)任務(wù)執(zhí)行周期特別說(shuō)明;
    的頭像 發(fā)表于 04-12 11:06 ?1081次閱讀

    Linux如何使用cron進(jìn)行定時(shí)任務(wù)的操作

    按計(jì)劃執(zhí)行命令對(duì)于計(jì)算機(jī)來(lái)說(shuō)非常重要,因?yàn)榧偃缥矣H自去執(zhí)行一些任務(wù)的話,可能會(huì)因?yàn)槎喾矫嬉蛩夭荒馨磿r(shí)執(zhí)行,所以定時(shí)任務(wù)就顯得非常重要了! cron就是一個(gè)能夠執(zhí)行定時(shí)任務(wù)的命令,其實(shí)該命令本身不難,下面小編帶您詳細(xì)了解!
    的頭像 發(fā)表于 05-12 16:27 ?2059次閱讀

    python定時(shí)任務(wù)實(shí)踐

    由于程序需求,監(jiān)測(cè)配置變化需要設(shè)置定時(shí)任務(wù),每分鐘執(zhí)行一次,對(duì)任務(wù)持久化要求不高,不需要時(shí)可以關(guān)閉定時(shí)任務(wù)
    的頭像 發(fā)表于 05-20 17:53 ?977次閱讀
    python<b class='flag-5'>定時(shí)任務(wù)</b>實(shí)踐

    linux定時(shí)任務(wù)的用法總結(jié)

    習(xí)慣了使用 windows 的計(jì)劃任務(wù),使用 linux 中的 crontab 管理定時(shí)任務(wù)時(shí)很不適應(yīng)。
    的頭像 發(fā)表于 08-14 18:16 ?851次閱讀
    linux<b class='flag-5'>定時(shí)任務(wù)</b>的用法總結(jié)