日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

Spring的任务调度@Scheduled注解——task:scheduler和task:executor的解析

發(fā)布時間:2025/3/12 javascript 41 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Spring的任务调度@Scheduled注解——task:scheduler和task:executor的解析 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

Spring的任務調(diào)度@Scheduled注解——task:scheduler和task:executor的解析

applicationContext 的配置如下:

<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans"xmlns:context="http://www.springframework.org/schema/context"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsdhttp://www.springframework.org/schema/task http://www.springframework.org/schema/task/spring-task-4.1.xsd"xmlns:task="http://www.springframework.org/schema/task"><context:annotation-config /><task:annotation-driven scheduler="myScheduler" executor="myExecutor"/><!-- 調(diào)度線程池配置 --><task:scheduler id="myScheduler" pool-size="5"/><!-- 執(zhí)行線程池配置 --><task:executor id="myExecutor" pool-size="5"/><context:component-scan base-package="com.zaimeibian" /></beans> package com.zaimeibian.task;import java.text.DateFormat; import java.text.SimpleDateFormat; import java.util.Date;import org.springframework.scheduling.annotation.Async; import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component;@Component public class PrintTask {DateFormat df = new SimpleDateFormat("HH:mm:ss");// 這個Async注解,代表當前任務是要異步執(zhí)行的@Async@Scheduled(fixedRate = 5000)public void printA(){System.out.println("A執(zhí)行 " + df.format(new Date()));try {Thread.sleep(10000);} catch (InterruptedException e) {}System.out.println("A打印輸出 " + df.format(new Date())+ Thread.currentThread());}@Scheduled(fixedRate = 5000)public void printB(){System.out.println("B執(zhí)行 " + df.format(new Date()));try {Thread.sleep(10000);} catch (InterruptedException e) {}System.out.println("B打印輸出 " + df.format(new Date())+ Thread.currentThread());}@Scheduled(fixedRate = 5000)public void printC(){System.out.println("C執(zhí)行 " + df.format(new Date()));try {Thread.sleep(10000);} catch (InterruptedException e) {}System.out.println("C打印輸出 " + df.format(new Date())+ Thread.currentThread());}// 配置initialDelay的任務是在容器啟動后延遲一定時間才開始調(diào)度@Scheduled(fixedRate = 5000, initialDelay=1000)public void printD(){System.out.println("D執(zhí)行 " + df.format(new Date()));try {Thread.sleep(30000);} catch (InterruptedException e) {}System.out.println("D打印輸出 " + df.format(new Date())+ Thread.currentThread());}// 配置initialDelay的任務是在容器啟動后延遲一定時間才開始調(diào)度@Scheduled(fixedRate = 5000, initialDelay=1000)public void printE(){System.out.println("E執(zhí)行 " + df.format(new Date()));try {Thread.sleep(30000);} catch (InterruptedException e) {}System.out.println("E打印輸出 " + df.format(new Date())+ Thread.currentThread());}}

這里,fixDelay 和 fixRate 參數(shù)代表每個任務,前者在上一個任務調(diào)度完成后,延遲一定的時間執(zhí)行。而后者可以在每間隔一定時間就執(zhí)行新任務(但這里與 executor 的參數(shù)有關(guān))。下面的試驗會詳細說明這兩個參數(shù)。
Spring 的任務調(diào)度線程池,即

<task:scheduler id="myScheduler" pool-size="5"/>

如果不配置,那么默認值是 1 ,即結(jié)果是所有聲明的任務,都是串行執(zhí)行的,比如代碼中的 A/B/C/D/E 五個任務,在默認值是 1 的情況下,只能一個個串行來執(zhí)行。不能出現(xiàn)并行的情況。
可以將參數(shù)改為 1 ,運行,輸出如下:

B執(zhí)行 12:16:36 B打印輸出 12:16:46Thread[myScheduler-1,5,main] A執(zhí)行 12:16:46 A打印輸出 12:16:56Thread[myScheduler-1,5,main] C執(zhí)行 12:16:56 C打印輸出 12:17:06Thread[myScheduler-1,5,main] D執(zhí)行 12:17:06 D打印輸出 12:17:36Thread[myScheduler-1,5,main] E執(zhí)行 12:17:36 E打印輸出 12:18:06Thread[myScheduler-1,5,main] B執(zhí)行 12:18:06 B打印輸出 12:18:16Thread[myScheduler-1,5,main] A執(zhí)行 12:18:16 A打印輸出 12:18:26Thread[myScheduler-1,5,main] C執(zhí)行 12:18:26 C打印輸出 12:18:36Thread[myScheduler-1,5,main] D執(zhí)行 12:18:36 D打印輸出 12:19:06Thread[myScheduler-1,5,main] E執(zhí)行 12:19:06 E打印輸出 12:19:36Thread[myScheduler-1,5,main] B執(zhí)行 12:19:36 B打印輸出 12:19:46Thread[myScheduler-1,5,main] A執(zhí)行 12:19:46 A打印輸出 12:19:56Thread[myScheduler-1,5,main]

可以看到只有 myScheduler-1 這一個調(diào)度線程來調(diào)度這五個任務,任務之間只能串行,即等待上個任務完成后釋放調(diào)度線程,然后調(diào)度線程才能調(diào)度執(zhí)行下一個任務。

然后我們還改回調(diào)度線程池 5 個線程池大小,運行:

C執(zhí)行 12:23:04 A執(zhí)行 12:23:04 B執(zhí)行 12:23:04 E執(zhí)行 12:23:05 D執(zhí)行 12:23:05 C打印輸出 12:23:14Thread[myScheduler-2,5,main] C執(zhí)行 12:23:14 A打印輸出 12:23:14Thread[myScheduler-3,5,main] A執(zhí)行 12:23:14 B打印輸出 12:23:14Thread[myScheduler-1,5,main] B執(zhí)行 12:23:14 C打印輸出 12:23:24Thread[myScheduler-2,5,main] C執(zhí)行 12:23:24 A打印輸出 12:23:24Thread[myScheduler-3,5,main] A執(zhí)行 12:23:24 B打印輸出 12:23:24Thread[myScheduler-1,5,main] B執(zhí)行 12:23:24 C打印輸出 12:23:34Thread[myScheduler-2,5,main] A打印輸出 12:23:34Thread[myScheduler-3,5,main] C執(zhí)行 12:23:34 A執(zhí)行 12:23:34 B打印輸出 12:23:34Thread[myScheduler-1,5,main] B執(zhí)行 12:23:34 E打印輸出 12:23:35Thread[myScheduler-4,5,main] E執(zhí)行 12:23:35 D打印輸出 12:23:35Thread[myScheduler-5,5,main] D執(zhí)行 12:23:35

可以看到,如果每個任務都有一個調(diào)度線程來處理,那么就是很理想的情況,各個任務之間是并行的,互不干擾各自獨立,按照各自的時間來觸發(fā)。(可以看到 1-5 這 5 個線程都在各自調(diào)度自己的任務)
這里還要注意一點,fixDelay 和 fixRate 看上去似乎是一樣的,在每個任務的調(diào)度線程中,都是必須上一個執(zhí)行完畢后,等待配置的時間后,再開始下一次的執(zhí)行。是不是 fixRate 參數(shù)不起作用呢?因為不是說 fixRate 是間隔一定時間執(zhí)行,而不需要等待上一個任務執(zhí)行完畢么?

這里引入另一個參數(shù),可以看任務 A 上方注釋掉的 @Async 注解:這個注解,代表可以異步執(zhí)行。異步執(zhí)行的話,調(diào)度線程池就會不用當前調(diào)度線程來執(zhí)行,而是交給 task:executor 這個執(zhí)行線程池來執(zhí)行。
我們來運行,這里為了更好的說明,我們可以把 A 的 fixRate 改為 2秒 ,看運行結(jié)果:

B執(zhí)行 12:34:44 C執(zhí)行 12:34:44 A執(zhí)行 12:34:44 D執(zhí)行 12:34:45 E執(zhí)行 12:34:45 A執(zhí)行 12:34:46 A執(zhí)行 12:34:48 A執(zhí)行 12:34:50 A執(zhí)行 12:34:52 B打印輸出 12:34:54Thread[myScheduler-2,5,main] B執(zhí)行 12:34:54 C打印輸出 12:34:54Thread[myScheduler-3,5,main] A打印輸出 12:34:54Thread[myExecutor-1,5,main] C執(zhí)行 12:34:54 A執(zhí)行 12:34:54 A打印輸出 12:34:56Thread[myExecutor-2,5,main] A執(zhí)行 12:34:56 A打印輸出 12:34:58Thread[myExecutor-3,5,main] A執(zhí)行 12:34:58 A打印輸出 12:35:00Thread[myExecutor-4,5,main] A執(zhí)行 12:35:00 A打印輸出 12:35:02Thread[myExecutor-5,5,main] A執(zhí)行 12:35:02 B打印輸出 12:35:04Thread[myScheduler-2,5,main] B執(zhí)行 12:35:04 C打印輸出 12:35:04Thread[myScheduler-3,5,main] A打印輸出 12:35:04Thread[myExecutor-1,5,main] C執(zhí)行 12:35:04 A執(zhí)行 12:35:04 A打印輸出 12:35:06Thread[myExecutor-2,5,main]

里 A 任務的線程是 myExecutor-1 到 myExecutor-5,說明 myScheduler-1 這個調(diào)度線程調(diào)度了 A 任務,但是交給了線程池中的 myExecutor 中的執(zhí)行線程來具體執(zhí)行的。
所以,配置 task:scheduler 參數(shù)的線程池,是為了根據(jù)任務總數(shù)來分配調(diào)度線程池的大小;而配置 task:executor ,是為了某個任務如果要異步的執(zhí)行時,實現(xiàn)當前任務內(nèi)的多線程并發(fā)。

總結(jié)

以上是生活随笔為你收集整理的Spring的任务调度@Scheduled注解——task:scheduler和task:executor的解析的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 国产三级久久久 | 美女隐私免费看 | 国产精品毛片一区二区在线看 | a级片日本 | 91色拍| 91啪在线| 欧美日韩高清在线播放 | 精品一区二区在线免费观看 | 中文字幕一区二区三区在线播放 | 精品91av| 一区二区免费在线观看视频 | 亚洲乱码精品久久久久.. | 精品午夜一区二区三区在线观看 | 男女涩涩| 亚洲精品久久久久久久蜜桃臀 | 国产乱码精品一区二区 | 欧美女优在线观看 | 久久久久久久极品内射 | 精品国产一区二区三区无码 | 又粗又猛又爽又黄少妇视频网站 | 国产精品69久久久久孕妇欧美 | 污视频大全 | 毛利兰被扒开腿做同人漫画 | 亚洲AV午夜精品 | 韩国成人在线 | 亚洲精品视频免费观看 | 夜色综合 | 成人国产综合 | 成年人黄色在线观看 | 日本吃奶摸下激烈网站动漫 | 欧美在线影院 | 久久亚洲AV无码精品 | 成人午夜视频免费观看 | 中文字幕一区二区三区精华液 | 少妇一级淫片免费播放 | 亚州a级片 | 成人在线中文字幕 | √8天堂资源地址中文在线 欧美精品在线一区二区 | 精品国产青草久久久久96 | 日韩欧美视频一区二区三区 | 暴操白虎 | 国内视频一区二区三区 | 91高跟黑色丝袜呻吟在线观看 | 国精品无码一区二区三区 | 久久午夜精品人妻一区二区三区 | 欧美三级免费 | 蜜臀av性久久久久蜜臀av麻豆 | 99久久精品国产亚洲 | 人人干人人搞 | 国产精品海角社区 | 老女人一毛片 | 51成人精品网站 | 日本免费在线视频观看 | 国产精品三级在线观看无码 | 成人香蕉视频在线观看 | 欧美性做爰毛片 | 男人和女人做爽爽视频 | 91午夜免费视频 | 欧美人狂配大交3d | 欧美永久免费 | 涩涩涩999 | 亚洲啪啪网址 | 97热视频| 欧美国产高潮xxxx1819 | 极品美女开粉嫩精品 | 日本中文字幕视频在线 | av永久免费在线观看 | 午夜视频在线免费看 | 强迫凌虐淫辱の牝奴在线观看 | 国产黄在线播放 | a级片在线观看 | 国产一级爱 | 免费看黄av | 日本福利在线观看 | 日韩精品中文字幕一区二区三区 | 性色生活片| 午夜肉体高潮免费毛片 | 九九精品在线播放 | 亚洲美女视频网站 | 最近高清中文在线字幕在线观看 | 亚洲免费中文字幕 | 日韩成人无码影院 | 羞羞网站在线观看 | 婷婷综合五月天 | 大香蕉视频一区二区 | 久久久久亚洲色欲AV无码网站 | av男人天堂av | 在线看国产视频 | 午夜影院一区二区 | 色多多在线观看 | 毛茸茸多毛bbb毛多视频 | 色01看片网 | 福利精品在线 | 欧美丝袜视频 | 日韩亚洲区 | 香蕉久久网站 | 欧美激情小视频 | 国产精品自拍视频一区 | 日韩人妻精品无码一区二区三区 |