国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

五分鐘搞定,實(shí)現(xiàn)定時(shí)任務(wù)的五種方案!

開發(fā) 前端
任務(wù)調(diào)度是指基于給定的時(shí)間點(diǎn),給定的時(shí)間間隔或者給定執(zhí)行次數(shù)自動(dòng)得執(zhí)行任務(wù)。任務(wù)調(diào)度是是操作系統(tǒng)的重要組成部分,而對于實(shí)時(shí)的操作系統(tǒng),任務(wù)調(diào)度直接影響著操作系統(tǒng)的實(shí)時(shí)性能。

我們在實(shí)際開發(fā)中,多多少少都會(huì)用到定時(shí)任務(wù)來處理一些問題。

比如金融項(xiàng)目中的對賬,每天定時(shí)對昨天的賬務(wù)進(jìn)行核對,每個(gè)月初對上個(gè)月的賬務(wù)進(jìn)行核對等。

還比如,我們需要處理一些老數(shù)據(jù)遷移,修復(fù)一些新項(xiàng)目和老項(xiàng)目數(shù)據(jù)不兼容的問題等等。

常規(guī)實(shí)現(xiàn)方案

方案1:Timer

這個(gè)目前在項(xiàng)目中用得較少,直接貼demo代碼。

具體的介紹可以查看api ,但是在某些框架中是有用到。

public class TestTimer {

public static void main(String[] args){

TimerTask timerTask = new TimerTask() {
@Override
public void run(){
System.out.println("task run:"+ new Date());
}
};

Timer timer = new Timer();
//安排指定的任務(wù)在指定的時(shí)間開始進(jìn)行重復(fù)的固定延遲執(zhí)行。這里是每3秒執(zhí)行一次
timer.schedule(timerTask,10,3000);
}
}

執(zhí)行結(jié)果:

task  run:Sun Dec 11 21:23:47 CST 2022
task run:Sun Dec 11 21:23:50 CST 2022
task run:Sun Dec 11 21:23:53 CST 2022

這么使用,阿里代碼檢查插件會(huì)提示:

圖片

從提示中可以看出,在多線程并行處理定時(shí)任務(wù)時(shí),Timer運(yùn)行多個(gè)TimerTask時(shí),只要有其中之一沒有捕獲拋出的異常,其他任務(wù)會(huì)自動(dòng)終止運(yùn)行。

方案2:ScheduledExecutorService

和Timer類型,也就是阿里代碼檢查插件推薦的方案:

public class TestScheduledExecutorService {

public static void main(String[] args){

ScheduledExecutorService service = Executors.newSingleThreadScheduledExecutor();
// 參數(shù):1、任務(wù)體 2、首次執(zhí)行的延時(shí)時(shí)間
// 3、任務(wù)執(zhí)行間隔 4、間隔時(shí)間單位
service.scheduleAtFixedRate(()->System.out.println("task ScheduledExecutorService "+new Date()), 0, 3, TimeUnit.SECONDS);
}
}

運(yùn)行結(jié)果:

task ScheduledExecutorService Sun Dec 11 21:30:06 CST 2022
task ScheduledExecutorService Sun Dec 11 21:30:09 CST 2022
task ScheduledExecutorService Sun Dec 11 21:30:12 CST 2022

阿里代碼檢查插件也會(huì)提示:

圖片

這里提示的是我們創(chuàng)建線程池的方式,建議我們使用手動(dòng)創(chuàng)建線程池,不要使用??Executors??工廠類,因?yàn)槭謩?dòng)創(chuàng)建更能有效規(guī)劃資源的使用。

方案3:spring task

用起來也非常簡單:

@Slf4j
@Component
public class ScheduledService {

@Scheduled(cron = "0/5 * * * * *")
public void scheduled(){
log.info("=====>>>>>使用cron {}",System.currentTimeMillis());
}

@Scheduled(fixedRate = 5000)
public void scheduled1(){
log.info("=====>>>>>使用fixedRate{}", System.currentTimeMillis());
}

@Scheduled(fixedDelay = 5000)
public void scheduled2(){
log.info("=====>>>>>fixedDelay{}",System.currentTimeMillis());
}

}

運(yùn)行結(jié)果:

2022-12-11 21:36:25.001  INFO 10660 --- [   scheduling-1] com.tian.utils.ScheduledService          : =====>>>>>使用cron  1670765785001
2022-12-11 21:36:28.212 INFO 10660 --- [ scheduling-1] com.tian.utils.ScheduledService : =====>>>>>使用fixedRate1670765788212
2022-12-11 21:36:28.212 INFO 10660 --- [ scheduling-1] com.tian.utils.ScheduledService : =====>>>>>fixedDelay1670765788212
2022-12-11 21:36:30.001 INFO 10660 --- [ scheduling-1] com.tian.utils.ScheduledService : =====>>>>>使用cron 1670765790001
2022-12-11 21:36:33.212 INFO 10660 --- [ scheduling-1] com.tian.utils.ScheduledService : =====>>>>>使用fixedRate1670765793212
2022-12-11 21:36:33.213 INFO 10660 --- [ scheduling-1] com.tian.utils.ScheduledService : =====>>>>>fixedDelay1670765793213
2022-12-11 21:36:35.001 INFO 10660 --- [ scheduling-1] com.tian.utils.ScheduledService : =====>>>>>使用cron 1670765795001
2022-12-11 21:36:38.214 INFO 10660 --- [ scheduling-1] com.tian.utils.ScheduledService : =====>>>>>使用fixedRate1670765798214
2022-12-11 21:36:38.214 INFO 10660 --- [ scheduling-1] com.tian.utils.ScheduledService : =====>>>>>fixedDelay1670765798214
2022-12-11 21:36:40.001 INFO 10660 --- [ scheduling-1] com.tian.utils.ScheduledService : =====>>>>>使用cron 1670765800001
2022-12-11 21:36:43.214 INFO 10660 --- [ scheduling-1] com.tian.utils.ScheduledService : =====>>>>>使用fixedRate1670765803214
2022-12-11 21:36:43.215 INFO 10660 --- [ scheduling-1] com.tian.utils.ScheduledService : =====>>>>>fixedDelay1670765803215

方案4:多線程執(zhí)行

基于注解設(shè)定多線程定時(shí)任務(wù) :

@Component
@EnableScheduling // 1.開啟定時(shí)任務(wù)
@EnableAsync // 2.開啟多線程
public class MultithreadScheduleTask {

@Async
@Scheduled(fixedDelay = 5000) //間隔5秒
public void first() throws InterruptedException {
System.out.println("第一個(gè)定時(shí)任務(wù)開始 : " + LocalDateTime.now().toLocalTime() + "\r\n線程 : " + Thread.currentThread().getName());
System.out.println();
Thread.sleep(1000 * 10);
}

@Async
@Scheduled(fixedDelay = 5000)
public void second(){
System.out.println("第二個(gè)定時(shí)任務(wù)開始 : " + LocalDateTime.now().toLocalTime() + "\r\n線程 : " + Thread.currentThread().getName());
System.out.println();
}
}

運(yùn)行結(jié)果:

第一個(gè)定時(shí)任務(wù)開始 : 21:44:02.800
線程 : 入庫操作日志記錄表 線程1

第二個(gè)定時(shí)任務(wù)開始 : 21:44:02.801
線程 : 入庫操作日志記錄表 線程2

第一個(gè)定時(shí)任務(wù)開始 : 21:44:07.801
線程 : 入庫操作日志記錄表 線程3

第二個(gè)定時(shí)任務(wù)開始 : 21:44:07.802
線程 : 入庫操作日志記錄表 線程4

第一個(gè)定時(shí)任務(wù)開始 : 21:44:12.807
線程 : 入庫操作日志記錄表 線程5

第二個(gè)定時(shí)任務(wù)開始 : 21:44:12.812
線程 : 入庫操作日志記錄表 線程6
......

方案5:quartz

我們需要引入依賴:

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-quartz</artifactId>
</dependency>

實(shí)現(xiàn)類:

public class Myquartz extends QuartzJobBean {
@Override
protected void executeInternal(JobExecutionContext context) throws JobExecutionException {
System.out.println("這是我的 quartz 定時(shí)任務(wù)");
}
}

配置類:

/**
* @author tianwc 公眾號(hào):java后端技術(shù)全棧、面試專欄
* @version 1.0.0
* @date 2022年12月11日 21:48
*/
@Configuration
public class QuartzConfig {

@Bean
public JobDetail teatQuartzDetail(){
return JobBuilder.newJob(MyQuartz.class).withIdentity("myQuartz").storeDurably().build();
}

@Bean
public Trigger testQuartzTrigger(){
SimpleScheduleBuilder scheduleBuilder = SimpleScheduleBuilder.simpleSchedule()

.withIntervalInSeconds(10) //設(shè)置時(shí)間周期單位秒
.repeatForever();

return TriggerBuilder.newTrigger().forJob(teatQuartzDetail())

.withIdentity("testQuartz")
.withSchedule(scheduleBuilder)
.build();
}
}

只要啟動(dòng)Spring Boot項(xiàng)目,就會(huì)輸出:

這是我的 quartz 定時(shí)任務(wù)
這是我的 quartz 定時(shí)任務(wù)
這是我的 quartz 定時(shí)任務(wù)

其他方案

我們在項(xiàng)目,可能會(huì)涉及動(dòng)態(tài)調(diào)整定時(shí)任務(wù)執(zhí)行core表達(dá)式、動(dòng)態(tài)關(guān)閉開啟定時(shí)任務(wù),我們可以使用??SchedulingConfigurer??來實(shí)現(xiàn)(使用數(shù)據(jù)庫結(jié)合來搞):

比如:

@Configuration
public class ScheduledConfig implements SchedulingConfigurer {
@Autowired
private ApplicationContext context;
@Override
public void configureTasks(ScheduledTaskRegistrar taskRegistrar){
for (SpringScheduledCron springScheduledCron : cronRepository.findAll()) {
Class<?> clazz;
Object task;
try {
clazz = Class.forName(springScheduledCron.getCronKey());
task = context.getBean(clazz);
} catch (ClassNotFoundException e) {
throw new IllegalArgumentException("spring_scheduled_cron表數(shù)據(jù)" + springScheduledCron.getCronKey() + "有誤", e);
} catch (BeansException e) {
throw new IllegalArgumentException(springScheduledCron.getCronKey() + "未納入到spring管理", e);
}
Assert.isAssignable(ScheduledOfTask.class, task.getClass(), "定時(shí)任務(wù)類必須實(shí)現(xiàn)ScheduledOfTask接口");
// 可以通過改變數(shù)據(jù)庫數(shù)據(jù)進(jìn)而實(shí)現(xiàn)動(dòng)態(tài)改變執(zhí)行周期
taskRegistrar.addTriggerTask(((Runnable) task),
triggerContext -> {
//這個(gè)可以使用持久層,比如Mybatis來實(shí)現(xiàn),從數(shù)據(jù)庫中獲取
String cronExpression = "0/10 * * * * ? "
return new CronTrigger(cronExpression).nextExecutionTime(triggerContext);
}
);
}
}
@Bean
public Executor taskExecutor(){
return Executors.newScheduledThreadPool(10);
}
}

如果項(xiàng)目中用得到類似的,可以網(wǎng)上搜搜SchedulingConfigurer便可實(shí)現(xiàn)。

進(jìn)而再擴(kuò)展,那就來到分布式任務(wù)調(diào)度了。

什么是分布式任務(wù)調(diào)度?

任務(wù)調(diào)度是指基于給定的時(shí)間點(diǎn),給定的時(shí)間間隔或者給定執(zhí)行次數(shù)自動(dòng)得執(zhí)行任務(wù)。任務(wù)調(diào)度是是操作系統(tǒng)的重要組成部分,而對于實(shí)時(shí)的操作系統(tǒng),任務(wù)調(diào)度直接影響著操作系統(tǒng)的實(shí)時(shí)性能。任務(wù)調(diào)度涉及到多線程并發(fā)、運(yùn)行時(shí)間規(guī)則定制及解析、線程池的維護(hù)等諸多方面的工作。

WEB服務(wù)器在接受請求時(shí),會(huì)創(chuàng)建一個(gè)新的線程服務(wù)。但是資源有限,必須對資源進(jìn)行控制,首先就是限制服務(wù)線程的最大數(shù)目,其次考慮以線程池共享服務(wù)的線程資源,降低頻繁創(chuàng)建、銷毀線程的消耗;然后任務(wù)調(diào)度信息的存儲(chǔ)包括運(yùn)行次數(shù)、調(diào)度規(guī)則以及運(yùn)行數(shù)據(jù)等。一個(gè)合適的任務(wù)調(diào)度框架對于項(xiàng)目的整體性能來說顯得尤為重要。

分布式任務(wù)調(diào)度框架有:cronsun、Elastic-job、saturn、lts、TBSchedule、xxl-job 等。

另外,就是cron表達(dá)式,推薦 http://www.pppet.net/

圖片

可以根據(jù)自己業(yè)務(wù)情況來,手動(dòng)選擇,自動(dòng)生成表達(dá)式。

責(zé)任編輯:武曉燕 來源: Java后端技術(shù)全棧
相關(guān)推薦

2024-07-10 18:55:09

Python定時(shí)

2021-12-01 06:50:50

Docker底層原理

2025-03-18 09:20:00

Go語言Golang

2017-09-27 11:00:50

LinuxBash使用技巧

2021-11-22 12:35:40

Python命令定時(shí)任務(wù)

2024-01-31 08:38:57

Python定時(shí)任務(wù)函數(shù)

2009-11-16 09:53:56

PHP上傳類

2015-12-03 14:10:26

systemd容器Linux

2020-02-21 19:54:09

HTTPS 配置手把手教

2023-04-04 09:13:15

2009-11-16 10:53:30

Oracle Hint

2024-12-11 07:00:00

面向?qū)ο?/a>代碼

2025-03-13 06:22:59

2025-05-26 10:25:00

防御性編程開發(fā)編程

2020-12-07 09:01:58

冪等系統(tǒng)f(f(x)) =f(

2020-06-16 08:47:53

磁盤

2009-10-21 18:19:36

VB.NET實(shí)現(xiàn)拖放

2024-06-25 12:25:12

LangChain路由鏈

2021-06-07 09:51:22

原型模式序列化

2009-11-05 14:53:54

Visual Stud
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

在线观看电影av| a屁视频一区二区三区四区| 91精品日本| 精品国产免费一区二区三区四区| 国模吧无码一区二区三区| 日韩福利视频网| 成人欧美一区二区三区黑人免费| 精品国产乱码久久久| 国内精品视频久久| 超碰精品在线观看| 欧美精品国产精品日韩精品| 欧美另类中文字幕| 九九精品视频在线观看| 欧美电影在线观看网站| 日韩天堂在线视频| 国产欧美视频在线| 性视频1819p久久| 亚洲精品国产精品粉嫩| 韩日欧美一区二区| 伊甸园亚洲一区| 国产精品午夜视频| 综合久久婷婷| 久久99精品久久久久久久久久 | 精品一区二区三区在线观看视频 | 国产精品老女人视频| 久久91精品| 国产精品国产三级国产aⅴ浪潮| 久久99国内| 国产欧美精品xxxx另类| 欧美激情第二页| 欧洲精品久久| 国产一区美女在线| 鲁一鲁一鲁一鲁一澡| 中文字幕av在线一区二区三区| 国产乱子视频| 在线观看日韩精品| 91色在线看| 日韩在线观看免费高清| 日韩美女国产精品| 国产乱人伦精品一区二区| 日韩精品免费视频人成| 欧美日韩二三区| 亚洲h精品动漫在线观看| 成人在线免费看黄| 亚洲欧美综合v| 亚洲动漫在线观看| 久久精品国产一区二区三区日韩 | 欧美一区成人| 清纯唯美一区二区三区| 波多野洁衣一区| 毛片毛片毛片毛片毛片毛片| 色综合久久久久综合体| 91美女精品| 欧美精品手机在线| 欧美一区亚洲| 黄色国产一级视频| 欧美视频在线观看免费| 毛片无码国产| 成人免费看吃奶视频网站| 激情综合色播激情啊| 开心快乐六月丁香婷婷| 亚洲国产精品va在线看黑人| 校园春色另类视频 | 国产精品免费看| 可以在线看的av网站| 精品日本美女福利在线观看| 波多视频一区| 国产综合香蕉五月婷在线| 久久激五月天综合精品| av成人动漫| 国产亚洲aⅴaaaaaa毛片| 1024精品久久久久久久久| 日韩伦理在线免费观看| 在线这里只有精品| 哺乳一区二区三区中文视频| 日韩在线电影一区| 亚洲综合色婷婷| 天然素人一区二区视频| 91久久国产综合久久蜜月精品| 成人黄色国产精品网站大全在线免费观看 | 欧美白人最猛性xxxxx69交| 日本高清久久| 久久久影院一区二区三区| 国产偷国产偷精品高清尤物| а√中文在线8| 国产精品久久久久久久久久尿| 国产999精品久久| 最新97超碰在线| 国产精品成人在线| 91麻豆国产精品久久| 9999热视频在线观看| 99精彩视频| 亚洲免费色视频| 小说区图片区亚洲| 亚欧洲精品在线视频免费观看| 亚洲在线免费播放| 中文字幕av一区二区三区四区| 五月天久久综合网| 欧美日韩在线影院| 国产精品三级| 成人毛片高清视频观看| 最近2019免费中文字幕视频三| 久久精品在线| 爱久久·www| 国产成人在线一区| 国产欧美精品在线观看| 国产精品久久亚洲不卡| 亚洲在线不卡| 日韩美女视频在线| 激情亚洲网站| 免费在线看污| 国产精品av免费在线观看| 中文字幕乱码日本亚洲一区二区| 国产亚洲精彩久久| 日韩视频 中文字幕| 亚洲精品xxxx| 久久爱www久久做| 久久大胆人体| 亚洲高清视频一区二区| 精品久久久久久无| 奇米四色…亚洲| 久久亚洲资源| 亚洲精品成人自拍| 亚洲国产福利在线| 久久国产精品色| 伊人久久国产| 欧美人与动牲交xxxxbbbb| 国产午夜精品视频| 国产福利一区在线观看| 欧美黑人巨大xxxxx| 免费看欧美黑人毛片| 主播福利视频一区| 91老师片黄在线观看| 国产成人澳门| 久草在线中文888| 亚洲在线第一页| 欧美在线观看18| 性一交一乱一区二区洋洋av| 欧美人与性动交α欧美精品济南到 | 亚洲www在线观看| 色乱码一区二区三区88| 综合久久婷婷| www.成人.com| 日本一区二区三区精品视频| 亚洲高清久久网| 丁香啪啪综合成人亚洲小说 | 精品久久久av| 国产精品三级av| 欧美日韩国产传媒| 国产三级在线观看| 日韩精品另类天天更新| 国产亚洲精品综合一区91| 国产午夜亚洲精品理论片色戒| 偷窥自拍亚洲色图精选| 亚亚洲欧洲精品| 欧美日韩国产免费一区二区三区| 亚洲福利精品在线| 久久精品亚洲乱码伦伦中文| 精品国产aⅴ| 色黄网站在线观看| 国产美女三级视频| 国产精品成人品| 9191国产精品| 99免费精品视频| 欧美丝袜一区| 国产在线观看免费麻豆| 男人操女人逼免费视频| 国产日产欧美a一级在线| 希岛爱理av一区二区三区| 91九色在线porn| 亚洲性视频网站| 欧美精品乱码久久久久久| 亚洲精华一区二区三区| av在线免费网址| 亚洲高清黄色| 91精品亚洲| 99久久精品网站| 国产一区二区三区免费在线观看| 国产精品香蕉| 亚洲看片一区| 极品销魂美女一区二区三区| 91亚洲精品一区二区乱码| 国产精品伦理在线| 国产精品九色蝌蚪自拍| 久久精品免费| 在线观看日韩av先锋影音电影院| 日韩午夜在线观看| 成人激情av| 亚洲高清在线免费观看| 免费a级在线播放| 加勒比视频一区| 成a人片亚洲日本久久| 国产91在线观看| 国产精品免费av| 欧美亚洲国产视频| 茄子视频成人免费观看| 亚洲在线第一页| 91精品国产入口| 中文字幕一区二区5566日韩| 狠狠爱www人成狠狠爱综合网|