一、業(yè)務(wù)場景
先說業(yè)務(wù)場景,根據(jù)用戶輸入的cron表達式進行定時調(diào)度,舉個例子:如圖

根據(jù)用戶輸入的參數(shù),生成表達式,然后定時去執(zhí)行相應(yīng)的業(yè)務(wù)邏輯。
二、Controller層(不是重點)
domain類
@TableName("sys_schedule")
@Data
public class Schedule {
private static final long serialVersionUID = 1L;
/**
* 主鍵ID
*/
@TableId(value = "id", type = IdType.AUTO)
private Long id;
/**
* 類型: 時間, 周, 日
*/
@TableField("type")
private Integer type;
/**
* time 時間
*/
@TableField("day_time")
private String dayTime;
/**
* time 周
*/
@TableField("weekday")
private String weekday;
/**
* time 日
*/
@TableField("monthday")
private String monthday;
/**
* 選中狀態(tài)
*/
@TableField("status")
private Integer status;
@TableField("cron")
private String cron;
@Override
public String toString() {
return "Schedule{" +
"id=" + id +
", type=" + type +
", dayTime='" + dayTime + '\\'' +
", weekday='" + weekday + '\\'' +
", monthday='" + monthday + '\\'' +
", status=" + status +
", cron='" + cron + '\\'' +
'}';
}
}
controller方法
@Autowired
private ScheduleService scheduleService;
@PutMapping("/editItem")
@ResponseBody
public ResponseData editItem(Schedule schedule) {
//ResponseData自己封裝的響應(yīng)結(jié)果
//param是你前端傳的,包含你的數(shù)據(jù),如cron表達式
this.scheduleService.update(schedule);
return ResponseData.success();
}
三、Service層
接口層
public interface ScheduleService {
/**
* 更新
* @Date 2020-12-25
*/
void update(Schedule param);
/**
* 業(yè)務(wù)處理
* @Date 2020-12-25
*/
void work();
}
實現(xiàn)層
@Service
public class ScheduleServiceImpl implements ScheduleService {
@Override
public void update(Schedule param) {
//這里簡化了我自己的業(yè)務(wù)邏輯代碼,根據(jù)公司自己需要來寫即可
//業(yè)務(wù)邏輯代碼
//思路就是:更新數(shù)據(jù)庫的cron,類型等值,然后交給下面的定時工具類走定時方法
this.scheduleMapper.updateById(param);
String cron = param.getCron();
//this就是你的業(yè)務(wù)執(zhí)行service, 這里就是scheduleService
ScheduleUtil.reset(new ScheduleTask(param.getId().toString(), this, null), cron);
}
@Override
public void work() {
//抓取數(shù)據(jù)的代碼
System.out.println("業(yè)務(wù)代碼執(zhí)行。。。");
}
}
四、定時工具類
import org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler;
import org.springframework.scheduling.support.CronTrigger;
import java.util.HashMap;
import java.util.Map;
import java.util.concurrent.ScheduledFuture;
public class ScheduleUtil {
private static ThreadPoolTaskScheduler threadPoolTaskScheduler = new ThreadPoolTaskScheduler();
private static Map<String, ScheduledFuture?> scheduledFutureMap = new HashMap<>();
static {
threadPoolTaskScheduler.initialize();
System.out.println("定時任務(wù)線程池啟動");
}
/**
* 啟動
*
* @param scheduleTask 定時任務(wù)
* @param corn 執(zhí)行時間表達式
*/
public static boolean start(ScheduleTask scheduleTask, String corn) {
System.out.println("啟動定時任務(wù)線程 taskId " + scheduleTask.getId());
ScheduledFuture? scheduledFuture = threadPoolTaskScheduler
.schedule(scheduleTask, new CronTrigger(corn));
scheduledFutureMap.put(scheduleTask.getId(), scheduledFuture);
return true;
}
/**
* 取消
*
* @param scheduleTask 定時任務(wù)
*/
public static boolean cancel(ScheduleTask scheduleTask) {
System.out.println("關(guān)閉定時任務(wù)線程 taskId " + scheduleTask.getId());
ScheduledFuture? scheduledFuture = scheduledFutureMap.get(scheduleTask.getId());
if (scheduledFuture != null && !scheduledFuture.isCancelled()) {
scheduledFuture.cancel(false);
}
scheduledFutureMap.remove(scheduleTask.getId());
return true;
}
/**
* 修改
*
* @param scheduleTask 定時任務(wù)
* @param corn 執(zhí)行時間表達式
*/
public static boolean reset(ScheduleTask scheduleTask, String corn) {
//先取消定時任務(wù)
cancel(scheduleTask);
//然后啟動新的定時任務(wù)
start(scheduleTask, corn);
return true;
}
}
五、工作線程
public class ScheduleTask implements Runnable {
private static final int TIMEOUT = 30000;
private String id;
private ScheduleService service;
public String getId() {
return id;
}
/**
* @param id 任務(wù)ID
* @param service 業(yè)務(wù)類
* @param keyword 關(guān)鍵字參數(shù)
*/
public ScheduleTask(String id, ScheduleService service) {
this.id = id;
this.service = service;
}
@Override
public void run() {
//你自己的業(yè)務(wù)邏輯
service.work();
}
}
到這里結(jié)束了,這里主要是根據(jù)前臺傳的時間,進行生成cron,入庫,執(zhí)行定時任務(wù)。但是有一個問題,就是如果項目重啟了的話,那么定時類那是無法加載到cron表達式的。那么接下來,加一個項目啟動時,把數(shù)據(jù)庫里的cron表達式重新灌入到定時類就可以。代碼如下:
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.CommandLineRunner;
import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;
/**
* 項目啟動時,加載
* @Date: 2020/12/25:16:00
**/
@Component
@Order(1)
public class initLineRunner implements CommandLineRunner {
@Autowired
private ScheduleService scheduleService;
@Override
public void run(String... args) throws Exception {
System.out.println("init ........... ");
//這里就是獲取你數(shù)據(jù)庫里的那個cron表達式
Schedule param = scheduleService.get();
String cron = param.getCron();
ScheduleUtil.reset(new ScheduleTask(param.getId().toString(), scheduleService, null), cron);
}
}
版權(quán)聲明:本文為博主原創(chuàng)文章,遵循 CC 4.0 BY-SA 版權(quán)協(xié)議,轉(zhuǎn)載請附上原文出處鏈接和本聲明。
本文鏈接:
https://blog.csdn.net/bbscz007/article/details/111695289
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。
舉報投訴
-
代碼
+關(guān)注
關(guān)注
30文章
4967瀏覽量
73954 -
spring
+關(guān)注
關(guān)注
0文章
341瀏覽量
15935 -
SpringBoot
+關(guān)注
關(guān)注
0文章
177瀏覽量
684
發(fā)布評論請先 登錄
相關(guān)推薦
熱點推薦
Linux系統(tǒng)定時任務(wù)Crond
會定期(默認每分鐘檢查一次)檢查系統(tǒng)中是否有要執(zhí)行的任務(wù)工作,如果有,便會根據(jù)其預(yù)先設(shè)定的定時任務(wù)規(guī)則自動執(zhí)行該定時任務(wù)工作,這個crond定時任務(wù)服務(wù)就相當于我們平時早起使用的鬧鐘一
發(fā)表于 07-05 06:22
OPC 實時任務(wù)系統(tǒng)動態(tài)調(diào)度算法的研究與設(shè)計The Stud
本文基于已有的OPC Server 實時任務(wù)模型,設(shè)計了處理混合任務(wù)集的動態(tài)調(diào)度算法(基于截止期優(yōu)先)和實現(xiàn)方式。該算法實現(xiàn)了對混合任集可調(diào)度
發(fā)表于 05-31 15:36
?13次下載
SpringBoot如何實現(xiàn)動態(tài)增刪啟停定時任務(wù)
這兩種方式不能動態(tài)添加、刪除、啟動、停止任務(wù)。 要實現(xiàn)動態(tài)增刪啟停定時任務(wù)功能,比較廣泛的做法是集成Quartz框架。但是本人的開發(fā)原則是:在滿足項目需求的情況下,盡量少的依賴其它框架
Python定時任務(wù)的實現(xiàn)方式
調(diào)度模塊schedule實現(xiàn)定時任務(wù) 利用任務(wù)框架APScheduler實現(xiàn)定時任務(wù) Job 作業(yè) Trigger 觸發(fā)器 Executor 執(zhí)行器 Jobstore 作業(yè)存儲 Eve
如何在SpringBoot項目中實現(xiàn)動態(tài)定時任務(wù)
之前寫過文章記錄怎么在SpringBoot項目中簡單使用定時任務(wù),不過由于要借助cron表達式且都提前定義好放在配置文件里,不能在項目運行中動態(tài)修改任務(wù)執(zhí)行時間,實在不太靈活。
解析Golang定時任務(wù)庫gron設(shè)計和原理
正巧,最近看到了 gron 這個開源項目,它是用 Golang 實現(xiàn)一個并發(fā)安全的定時任務(wù)庫。實現(xiàn)非常簡單精巧,代碼量也不多。今天我們就來一起結(jié)合源碼看一下,怎樣基于 Golang 的能力做出來一個【定時任務(wù)庫】。
xxl-job任務(wù)調(diào)度中間件解決定時任務(wù)的調(diào)度問題
xxl-job是一款非常優(yōu)秀的任務(wù)調(diào)度中間件,輕量級、使用簡單、支持分布式等優(yōu)點,讓它廣泛應(yīng)用在我們的項目中,解決了不少定時任務(wù)的調(diào)度問題。
求一種SpringBoot定時任務(wù)動態(tài)管理通用解決方案
SpringBoot的定時任務(wù)的加強工具,實現(xiàn)對SpringBoot原生的定時任務(wù)進行動態(tài)管理,完全兼容原生@Scheduled注解,無需對
SpringBoot如何實現(xiàn)定時任務(wù)(下)
SpringBoot創(chuàng)建定時任務(wù)的方式很簡單,主要有兩種方式:一、基于注解的方式(@Scheduled)二、數(shù)據(jù)庫動態(tài)配置。實際開發(fā)中,第一種需要在代碼中寫死表達式,如果修改起來,又得重啟會顯得很麻煩;所以我們往往會采取第二種方
SpringBoot如何實現(xiàn)定時任務(wù)(上)
SpringBoot創(chuàng)建定時任務(wù)的方式很簡單,主要有兩種方式:一、基于注解的方式(@Scheduled)二、數(shù)據(jù)庫動態(tài)配置。實際開發(fā)中,第一種需要在代碼中寫死表達式,如果修改起來,又得重啟會顯得很麻煩;所以我們往往會采取第二種方
在Spring Boot中如何使用定時任務(wù)
本文介紹在 Spring Boot 中如何使用定時任務(wù),使用非常簡單,就不做過多說明了。
如何動態(tài)添加修改刪除定時任務(wù)?
如何動態(tài)添加修改刪除定時任務(wù)?那么我們一起看看具體怎么實現(xiàn),先看下本節(jié)大綱:
(1)思路說明;
(2)代碼解析;
(3)修改定時任務(wù)執(zhí)行周期特別說明;
Linux如何使用cron進行定時任務(wù)的操作
按計劃執(zhí)行命令對于計算機來說非常重要,因為假如我親自去執(zhí)行一些任務(wù)的話,可能會因為多方面因素不能按時執(zhí)行,所以定時任務(wù)就顯得非常重要了!
cron就是一個能夠執(zhí)行定時任務(wù)的命令,其實該命令本身不難,下面小編帶您詳細了解!
python定時任務(wù)實踐
由于程序需求,監(jiān)測配置變化需要設(shè)置定時任務(wù),每分鐘執(zhí)行一次,對任務(wù)持久化要求不高,不需要時可以關(guān)閉定時任務(wù)
SpringBoot-動態(tài)定時任務(wù)調(diào)度
評論