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

Springboot整合xxl-job實(shí)現(xiàn)動(dòng)態(tài)傳參

 更新時(shí)間:2025年03月18日 09:53:29   作者:SoftwareDevOps  
XXL-JOB是一個(gè)分布式任務(wù)調(diào)度平臺(tái),本文主要介紹了Springboot整合xxl-job實(shí)現(xiàn)動(dòng)態(tài)傳參,具有一定的參考價(jià)值,感興趣的可以了解一下

在做項(xiàng)目的時(shí)候,關(guān)于定時(shí)任務(wù)框架的首選,肯定是xxl-job,那么關(guān)于xxl-job你有多少了解呢?

1、什么是xxl-job?

一、基本組成

XXL-JOB主要由調(diào)度中心和執(zhí)行器兩部分組成:

調(diào)度中心:統(tǒng)一管理任務(wù)調(diào)度平臺(tái)上的調(diào)度任務(wù),負(fù)責(zé)觸發(fā)調(diào)度執(zhí)行,并且提供任務(wù)管理平臺(tái)。它主要負(fù)責(zé)管理調(diào)度信息,按照調(diào)度配置發(fā)出調(diào)度請(qǐng)求,但自身不承擔(dān)業(yè)務(wù)代碼。
執(zhí)行器:接收調(diào)度中心的調(diào)度并且執(zhí)行,可以直接執(zhí)行也可以集成到項(xiàng)目中。它負(fù)責(zé)接收調(diào)度請(qǐng)求并執(zhí)行任務(wù)邏輯,包括執(zhí)行請(qǐng)求、終止請(qǐng)求和日志請(qǐng)求等。

二、特點(diǎn)與優(yōu)勢(shì)

簡(jiǎn)單易用:XXL-JOB提供了友好的Web界面,支持通過Web界面進(jìn)行任務(wù)的增刪改查,同時(shí)也支持通過API接口進(jìn)行任務(wù)管理。用戶可以通過簡(jiǎn)單的操作完成任務(wù)的調(diào)度和管理。
動(dòng)態(tài)管理:支持動(dòng)態(tài)修改任務(wù)狀態(tài)、啟動(dòng)/停止任務(wù)以及終止運(yùn)行中任務(wù),所有操作都會(huì)實(shí)時(shí)生效。
高可用性:調(diào)度中心和執(zhí)行器都支持集群部署,可保證調(diào)度和執(zhí)行的高可用性。即使某個(gè)節(jié)點(diǎn)出現(xiàn)故障,也能自動(dòng)切換到其他節(jié)點(diǎn)繼續(xù)執(zhí)行任務(wù)。
彈性擴(kuò)容縮容:一旦有新執(zhí)行器機(jī)器上線或者下線,下次調(diào)度時(shí)將會(huì)重新分配任務(wù),實(shí)現(xiàn)彈性擴(kuò)容縮容。
豐富的路由策略:執(zhí)行器集群部署時(shí)提供多種路由策略,包括第一個(gè)、最后一個(gè)、輪詢、隨機(jī)、一致性HASH等,以滿足不同場(chǎng)景下的需求。
故障轉(zhuǎn)移:如果執(zhí)行器集群中某一臺(tái)機(jī)器故障,將會(huì)自動(dòng)Failover切換到一臺(tái)正常的執(zhí)行器發(fā)送調(diào)度請(qǐng)求,確保任務(wù)能夠正常執(zhí)行。
執(zhí)行失敗查看日志:對(duì)于執(zhí)行失敗的任務(wù),可以查看詳細(xì)的日志信息,方便用戶進(jìn)行問題排查和修復(fù)。
支持郵件報(bào)警:當(dāng)任務(wù)執(zhí)行失敗時(shí),XXL-JOB支持發(fā)送郵件通知相關(guān)人員,以便及時(shí)處理異常情況。

三、應(yīng)用場(chǎng)景

XXL-JOB適用于各種需要定時(shí)執(zhí)行任務(wù)或?qū)崟r(shí)處理任務(wù)的場(chǎng)景,如:

定時(shí)發(fā)送郵件:通過XXL-JOB可以定時(shí)發(fā)送郵件通知相關(guān)人員。
定時(shí)生成報(bào)表:可以定時(shí)生成各類業(yè)務(wù)報(bào)表,供相關(guān)人員進(jìn)行分析和決策。
定時(shí)清理數(shù)據(jù):可以定時(shí)清理過期或無效的數(shù)據(jù),確保數(shù)據(jù)庫的整潔和高效運(yùn)行。
實(shí)時(shí)數(shù)據(jù)采集:可以實(shí)時(shí)采集各類業(yè)務(wù)數(shù)據(jù),并進(jìn)行處理和分析。
實(shí)時(shí)消息推送:可以實(shí)時(shí)推送各類業(yè)務(wù)消息給用戶或第三方系統(tǒng)。

四、與其他任務(wù)調(diào)度框架的比較

與Quartz等傳統(tǒng)的任務(wù)調(diào)度框架相比,XXL-JOB具有以下優(yōu)勢(shì):

學(xué)習(xí)成本低:XXL-JOB提供了可視化的Web界面和豐富的文檔支持,降低了學(xué)習(xí)成本。
操作簡(jiǎn)便:通過Web界面可以方便地進(jìn)行任務(wù)的創(chuàng)建、編輯、刪除和查詢等操作。
負(fù)載均衡:XXL-JOB通過執(zhí)行器實(shí)現(xiàn)協(xié)同分配式運(yùn)行任務(wù),充分發(fā)揮集群優(yōu)勢(shì),實(shí)現(xiàn)了負(fù)載均衡。

2、xxl-job如何動(dòng)態(tài)傳參?

  • 通過任務(wù)參數(shù)字段
    在XXL-JOB的任務(wù)管理界面,每個(gè)任務(wù)都有一個(gè)“任務(wù)參數(shù)”字段。你可以在這個(gè)字段中填寫需要傳遞給執(zhí)行器的參數(shù)。這些參數(shù)通常以JSON、鍵值對(duì)或其他格式編寫,具體取決于你的執(zhí)行器如何解析這些參數(shù)。

例如,你可以在“任務(wù)參數(shù)”字段中填寫:

{
    "param1": "value1",
    "param2": "value2"
}

然后在執(zhí)行器的任務(wù)處理邏輯中,通過某種方式(如Jackson庫)解析這個(gè)JSON字符串,獲取到具體的參數(shù)值。

  • 通過自定義參數(shù)傳遞
    XXL-JOB支持通過調(diào)度中心傳遞自定義參數(shù)給執(zhí)行器。你可以在創(chuàng)建或編輯任務(wù)時(shí),在“GLUE源碼”或“Bean模式”下編寫代碼,通過XxlJobHelper.getXxlJobContext()獲取到當(dāng)前的任務(wù)上下文,然后從上下文中提取出自定義參數(shù)。

例如,在GLUE源碼模式下,你可以這樣編寫代碼:

import com.xxl.job.core.biz.model.ReturnT;
import com.xxl.job.core.handler.annotation.XxlJob;
import com.xxl.job.core.logger.XxlJobLogger;
import com.xxl.job.core.util.XxlJobHelper;

import java.util.Map;

@XxlJob("demoJobHandler")
public class DemoJobHandler {

    @Override
    public ReturnT<String> execute(String param) throws Exception {
        // 獲取任務(wù)上下文
        Map<String, Object> context = XxlJobHelper.getXxlJobContext().getCustomParam();
        
        // 從上下文中提取參數(shù)
        String customParam1 = (String) context.get("customParam1");
        String customParam2 = (String) context.get("customParam2");
        
        // 執(zhí)行任務(wù)邏輯
        XxlJobLogger.log("customParam1: " + customParam1 + ", customParam2: " + customParam2);
        
        return ReturnT.SUCCESS;
    }
}

但是,請(qǐng)注意,上面的代碼示例并不完全準(zhǔn)確,因?yàn)閄xlJobHelper.getXxlJobContext().getCustomParam()方法可能并不存在(具體取決于XXL-JOB的版本和你的配置)。實(shí)際上,你可能需要通過其他方式獲取自定義參數(shù),例如通過任務(wù)參數(shù)字段傳遞一個(gè)JSON字符串,并在執(zhí)行器代碼中解析這個(gè)字符串。

  • 通過全局參數(shù)配置
    XXL-JOB還支持全局參數(shù)配置,這些參數(shù)可以在調(diào)度中心的全局配置中設(shè)置,并在執(zhí)行器啟動(dòng)時(shí)通過配置文件或命令行參數(shù)等方式傳遞給執(zhí)行器。然而,這種方式通常用于傳遞一些不變的全局配置信息,而不是動(dòng)態(tài)的任務(wù)參數(shù)。

  • 通過API接口傳遞
    如果你的應(yīng)用場(chǎng)景需要更加靈活和動(dòng)態(tài)的參數(shù)傳遞方式,你可以考慮通過API接口來觸發(fā)任務(wù),并在API請(qǐng)求中傳遞參數(shù)。XXL-JOB提供了RESTful API接口,你可以通過HTTP請(qǐng)求來觸發(fā)任務(wù),并在請(qǐng)求體中傳遞參數(shù)。

到此這篇關(guān)于Springboot整合xxl-job實(shí)現(xiàn)動(dòng)態(tài)傳參  的文章就介紹到這了,更多相關(guān)Springboot xxl-job動(dòng)態(tài)傳參  內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • java排序去重示例分享

    java排序去重示例分享

    這篇文章主要介紹了java排序去重示例,對(duì)String strs = "ZZZ BBB AAA OOO ZZZ AAA ZZZ"計(jì)算出現(xiàn)個(gè)數(shù),排序去重,需要的朋友可以參考下
    2014-02-02
  • Java 數(shù)據(jù)結(jié)構(gòu)進(jìn)階二叉樹題集上

    Java 數(shù)據(jù)結(jié)構(gòu)進(jìn)階二叉樹題集上

    二叉樹可以簡(jiǎn)單理解為對(duì)于一個(gè)節(jié)點(diǎn)來說,最多擁有一個(gè)上級(jí)節(jié)點(diǎn),同時(shí)最多具備左右兩個(gè)下級(jí)節(jié)點(diǎn)的數(shù)據(jù)結(jié)構(gòu)。本文將帶你通過實(shí)際題目來熟練掌握
    2022-04-04
  • java實(shí)現(xiàn)word文檔轉(zhuǎn)pdf并添加水印的方法詳解

    java實(shí)現(xiàn)word文檔轉(zhuǎn)pdf并添加水印的方法詳解

    這篇文章主要介紹了java實(shí)現(xiàn)word文檔轉(zhuǎn)pdf并添加水印的方法,結(jié)合實(shí)例形式詳細(xì)分析了java word文檔轉(zhuǎn)PDF相關(guān)實(shí)現(xiàn)技巧與操作注意事項(xiàng),需要的朋友可以參考下
    2019-09-09
  • Java Lambda表達(dá)式實(shí)例解析原理

    Java Lambda表達(dá)式實(shí)例解析原理

    日常開發(fā)中,我們很多時(shí)候需要用到Java?8的Lambda表達(dá)式,它允許把函數(shù)作為一個(gè)方法的參數(shù),讓我們的代碼更優(yōu)雅、更簡(jiǎn)潔。所以整理了一波工作中常用的Lambda表達(dá)式。看完一定會(huì)有幫助的
    2023-03-03
  • 關(guān)于Spring Boot對(duì)jdbc的支持問題

    關(guān)于Spring Boot對(duì)jdbc的支持問題

    這篇文章主要介紹了關(guān)于Spring Boot對(duì)jdbc的支持問題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-04-04
  • Java實(shí)現(xiàn)JSON與XML相互轉(zhuǎn)換的簡(jiǎn)明教程

    Java實(shí)現(xiàn)JSON與XML相互轉(zhuǎn)換的簡(jiǎn)明教程

    Java實(shí)現(xiàn)復(fù)雜數(shù)據(jù)結(jié)構(gòu)(如嵌套對(duì)象、數(shù)組)在 JSON 與 XML 之間的相互轉(zhuǎn)換,可以使用 Jackson 和 Jackson XML 擴(kuò)展庫來完成,Jackson 是一個(gè)流行的 JSON 處理庫,通過 Jackson 的 XML 擴(kuò)展庫,可以實(shí)現(xiàn) JSON 和 XML 之間的轉(zhuǎn)換,需要的朋友可以參考下
    2024-08-08
  • 解析Java中所有錯(cuò)誤和異常的父類java.lang.Throwable

    解析Java中所有錯(cuò)誤和異常的父類java.lang.Throwable

    這篇文章主要介紹了Java中所有錯(cuò)誤和異常的父類java.lang.Throwable,文章中簡(jiǎn)單地分析了其源碼,說明在代碼注釋中,需要的朋友可以參考下
    2016-03-03
  • SpringBoot-JWT生成Token和攔截器的使用(訪問受限資源)

    SpringBoot-JWT生成Token和攔截器的使用(訪問受限資源)

    本文主要介紹了SpringBoot-JWT生成Token和攔截器的使用(訪問受限資源),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05
  • Mybatis批量插入數(shù)據(jù)返回主鍵的實(shí)現(xiàn)

    Mybatis批量插入數(shù)據(jù)返回主鍵的實(shí)現(xiàn)

    這篇文章主要介紹了Mybatis批量插入數(shù)據(jù)返回主鍵的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-01-01
  • Java commons-httpclient如果實(shí)現(xiàn)get及post請(qǐng)求

    Java commons-httpclient如果實(shí)現(xiàn)get及post請(qǐng)求

    這篇文章主要介紹了Java commons-httpclient如果實(shí)現(xiàn)get及post請(qǐng)求,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-09-09

最新評(píng)論