日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當(dāng)前位置:首頁 > 科技  > 軟件

springboot-如何配置線程池實(shí)現(xiàn)定時任務(wù)

來源: 責(zé)編: 時間:2024-02-29 14:39:36 205觀看
導(dǎo)讀一、步驟概覽二、步驟說明1.封裝自定義線程池封裝自定義線程池類是為了在線程執(zhí)行完畢后,我們檢查是否存在異常,如果存在異常,日志打印詳細(xì)異常信息,這樣可以可以幫助我們及時發(fā)現(xiàn)和解決問題。JDK 默認(rèn)提供的定時調(diào)度線

一、步驟概覽

jKL28資訊網(wǎng)——每日最新資訊28at.com

二、步驟說明

1.封裝自定義線程池

封裝自定義線程池類是為了在線程執(zhí)行完畢后,我們檢查是否存在異常,如果存在異常,日志打印詳細(xì)異常信息,這樣可以可以幫助我們及時發(fā)現(xiàn)和解決問題。jKL28資訊網(wǎng)——每日最新資訊28at.com

JDK 默認(rèn)提供的定時調(diào)度線程池類是
ScheduledThreadPoolExecutor,我們只需要繼承它并重寫它的 afterExecute 方法,添加異常日志打印的邏輯。
jKL28資訊網(wǎng)——每日最新資訊28at.com

  • MyScheduledThreadPoolExecutor
public class MyScheduledThreadPoolExecutor extends ScheduledThreadPoolExecutor {    private Logger log = LoggerFactory.getLogger(MyScheduledThreadPoolExecutor.class);    public MyScheduledThreadPoolExecutor(int corePoolSize, ThreadFactory factory) {        super(corePoolSize, factory);    }    @Override    protected void afterExecute(Runnable r, Throwable t) {        super.afterExecute(r, t);        // 打印異常信息        this.printException(r, t);    }    public void printException(Runnable r, Throwable t) {        // 判斷 r 是 Future 實(shí)例并且已經(jīng)完成執(zhí)行的情況下,獲取它的執(zhí)行結(jié)果,并檢查是否有異常拋出        if (t == null && r instanceof Future<?>) {            try {                Future<?> future = (Future<?>) r;                if (future.isDone()) {                    future.get();                }            } catch (CancellationException ce) {                t = ce;            } catch (ExecutionException ee) {                t = ee.getCause();            } catch (InterruptedException ie) {                Thread.currentThread().interrupt();            }        }        if (t != null) {            log.error(t.getMessage(), t);        }    }}

2.定義調(diào)度配置

創(chuàng)建 ScheduleConfig 類,用于配置定時調(diào)度的執(zhí)行器。代碼概覽如圖所示:jKL28資訊網(wǎng)——每日最新資訊28at.com

jKL28資訊網(wǎng)——每日最新資訊28at.com

① 創(chuàng)建定時調(diào)度線程池jKL28資訊網(wǎng)——每日最新資訊28at.com

使用自定義封裝的線程池類,創(chuàng)建線程池,指定線程池創(chuàng)建線程名前綴,并將其設(shè)置成應(yīng)用程序的守護(hù)線程。jKL28資訊網(wǎng)——每日最新資訊28at.com

  • ScheduleConfig#taskExecutor
@Bean(destroyMethod="shutdown")public ExecutorService taskExecutor() {  ThreadFactory factory = new BasicThreadFactory.Builder()    .namingPattern("schedule-pool-%d")    .daemon(true)    .build();  return new MyScheduledThreadPoolExecutor(10, factory);}

② 設(shè)置任務(wù)調(diào)度器jKL28資訊網(wǎng)——每日最新資訊28at.com

實(shí)現(xiàn) SchedulingConfigurer 接口,重寫 configureTasks 方法,允許我們對任務(wù)調(diào)度進(jìn)行自定義配置,這邊我們將我們自定義創(chuàng)建的線程池設(shè)置成任務(wù)調(diào)度器。jKL28資訊網(wǎng)——每日最新資訊28at.com

  • ScheduleConfig#configureTasks
@Configurationpublic class ScheduleConfig implements SchedulingConfigurer {    @Override    public void configureTasks(ScheduledTaskRegistrar taskRegistrar) {        // 自定義線程池作為調(diào)度器        taskRegistrar.setScheduler(taskExecutor());    }}

3.啟用調(diào)度

在應(yīng)用啟動類上添加注解 `@EnableScheduling`,用于啟用定時調(diào)度,操作如圖所示:jKL28資訊網(wǎng)——每日最新資訊28at.com

jKL28資訊網(wǎng)——每日最新資訊28at.com

4.注解標(biāo)記調(diào)度策略

在我們需要定時執(zhí)行的方法上使用相關(guān)注解,標(biāo)記其調(diào)度策略。jKL28資訊網(wǎng)——每日最新資訊28at.com

①.固定時間執(zhí)行jKL28資訊網(wǎng)——每日最新資訊28at.com

如果需要在固定的時間點(diǎn)執(zhí)行任務(wù),可以使用 @Scheduled(cron = "表達(dá)式") 注解來指定 cron 表達(dá)式,如下所示:jKL28資訊網(wǎng)——每日最新資訊28at.com

@Componentpublic class MyTask {    @Scheduled(cron = "0 0 12 * * ?")    public void runTask() {        // 在每天中午 12 點(diǎn)執(zhí)行任務(wù)    }}

其中 cron 表達(dá)式使用說明如下表格所示jKL28資訊網(wǎng)——每日最新資訊28at.com

位數(shù)jKL28資訊網(wǎng)——每日最新資訊28at.com

字段jKL28資訊網(wǎng)——每日最新資訊28at.com

允許值jKL28資訊網(wǎng)——每日最新資訊28at.com

1jKL28資訊網(wǎng)——每日最新資訊28at.com

jKL28資訊網(wǎng)——每日最新資訊28at.com

0-59jKL28資訊網(wǎng)——每日最新資訊28at.com

2jKL28資訊網(wǎng)——每日最新資訊28at.com

分鐘jKL28資訊網(wǎng)——每日最新資訊28at.com

0-59jKL28資訊網(wǎng)——每日最新資訊28at.com

3jKL28資訊網(wǎng)——每日最新資訊28at.com

小時jKL28資訊網(wǎng)——每日最新資訊28at.com

0-23jKL28資訊網(wǎng)——每日最新資訊28at.com

4jKL28資訊網(wǎng)——每日最新資訊28at.com

日期jKL28資訊網(wǎng)——每日最新資訊28at.com

1-31jKL28資訊網(wǎng)——每日最新資訊28at.com

5jKL28資訊網(wǎng)——每日最新資訊28at.com

月份jKL28資訊網(wǎng)——每日最新資訊28at.com

1-12 或 JAN-DECjKL28資訊網(wǎng)——每日最新資訊28at.com

6jKL28資訊網(wǎng)——每日最新資訊28at.com

星期jKL28資訊網(wǎng)——每日最新資訊28at.com

0-6 或 SUN-SAT,其中 0 和 7 都表示周日jKL28資訊網(wǎng)——每日最新資訊28at.com

7jKL28資訊網(wǎng)——每日最新資訊28at.com

年(可選)jKL28資訊網(wǎng)——每日最新資訊28at.com

空白表示任意年,或者指定特定年份,如 2022、2023jKL28資訊網(wǎng)——每日最新資訊28at.com

② 間隔執(zhí)行jKL28資訊網(wǎng)——每日最新資訊28at.com

如果需要在固定的時間間隔內(nèi)周期性地執(zhí)行任務(wù),可以使用 @Scheduled(fixedRate = 時間間隔) 或 @Scheduled(fixedDelay = 時間間隔) 注解來指定時間間隔,如下所示:jKL28資訊網(wǎng)——每日最新資訊28at.com

@Componentpublic class MyTask {    @Scheduled(fixedRate = 5000)    public void runTask() {        // 每 5 秒執(zhí)行一次任務(wù)    }}

③延遲執(zhí)行jKL28資訊網(wǎng)——每日最新資訊28at.com

如果需要在應(yīng)用啟動后延遲一段時間后執(zhí)行任務(wù),可以使用 @Scheduled(initialDelay = 延遲時間) 注解來指定延遲時間,如下所示:jKL28資訊網(wǎng)——每日最新資訊28at.com

@Componentpublic class MyTask {    @Scheduled(initialDelay = 5000, fixedRate = 5000)    public void runTask() {        // 在應(yīng)用啟動后延遲 5 秒執(zhí)行任務(wù),之后每 5 秒執(zhí)行一次任務(wù)    }}

三、代碼測試

我們就以間隔執(zhí)行進(jìn)行測試,測試方法每3秒執(zhí)行一次。jKL28資訊網(wǎng)——每日最新資訊28at.com

1.測試代碼

@Slf4j@Servicepublic class FixedDelayTask {    private static int count1 = 1;    @Scheduled(fixedDelay = 3000)    public void fixedDelay() {        log.info(String.format("第%s次執(zhí)行", count1++));    }}
2.測試結(jié)果

jKL28資訊網(wǎng)——每日最新資訊28at.com

兩次執(zhí)行相隔3秒鐘,并且線程名也是以我們自定義的為前綴。jKL28資訊網(wǎng)——每日最新資訊28at.com

本文鏈接:http://www.www897cc.com/showinfo-26-75309-0.htmlspringboot-如何配置線程池實(shí)現(xiàn)定時任務(wù)

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: C++魔法技能:類型強(qiáng)制轉(zhuǎn)換全指南

下一篇: Vue2問題:分享一個通用多文件類型預(yù)覽庫

標(biāo)簽:
  • 熱門焦點(diǎn)
Top 主站蜘蛛池模板: 鄄城县| 贺州市| 民乐县| 瑞丽市| 紫云| 两当县| 台东市| 上蔡县| 五原县| 安岳县| 上犹县| 文山县| 景德镇市| 镇坪县| 兖州市| 息烽县| 岳普湖县| 江山市| 揭东县| 都匀市| 靖远县| 泾川县| 崇信县| 麻栗坡县| 宜城市| 丹阳市| 大庆市| 河间市| 吉木萨尔县| 福建省| 交口县| 玉树县| 桐柏县| 五台县| 日照市| 景德镇市| 灵川县| 土默特右旗| 应用必备| 高要市| 西城区|