網(wǎng)站首頁 編程語言 正文
一、背景
例如需要在某年某月去將數(shù)據(jù)庫的某個數(shù)據(jù)更新或者同步,又或者是每隔一段時間來執(zhí)行一部分代碼去調用接口,但是又不想人為的手動去執(zhí)行
針對此類業(yè)務可以使用"定時調用任務",市面上有很多的定時調度任務框架,甚至你可以使用定時器來結合Windows服務做一個簡易版的任務調度程序,此處我們學習Quartz,因為Quartz是一個強大、開源、輕量級的任務調度框架,支持cron-like表達式其他一些優(yōu)秀的特性。
二、Quartz
1.基本概念
Scheduler | Trigger | Job |
---|---|---|
調度器,quartz工作時的獨立容器 | 觸發(fā)器,定義了調度任務的時間規(guī)則 | 調用任務具體要執(zhí)行的動作的容器 |
2.初步使用
1.Nuget引入QuartZ程序集
2.創(chuàng)建一個Scheduler任務調度容器
3.指定具體執(zhí)行的任務Job和觸發(fā)器
4.把策略和任務放入到Scheduler并啟動
public class QuartzManager { public async static void Init() { StdSchedulerFactory factory = new StdSchedulerFactory(); //創(chuàng)建一個Scheduler任務調度容器 IScheduler scheduler = await factory.GetScheduler(); //指定具體執(zhí)行的任務Job IJobDetail sendEmailJob = JobBuilder.Create<SendMailJob>() .WithIdentity("sendEmailJob", "sendEmailJobGrop") .WithDescription("定時發(fā)送郵件").Build(); //設置觸發(fā)條件為五秒執(zhí)行一次 ITrigger sendEmailTrigger = TriggerBuilder.Create() .WithIdentity("sendEmailTrigger", "sendEmailJobGrop" .WithDescription("QuartZ") .WithCronSchedule("3/5 * * * * ?") .Build(); //把策略和任務放入到Scheduler await scheduler.ScheduleJob(sendEmailJob, sendEmailTrigger); //執(zhí)行任務 await scheduler.Start(); } } //增加特性保證任務不會重疊執(zhí)行 [DisallowConcurrentExecution] public class SendMailJob : IJob { //Job類 public async Task Execute(IJobExecutionContext context) { await Task.Run(() => { //doSomthing Console.WriteLine($"開始發(fā)送郵件{DateTime.Now}"); }); } }
三、傳遞參數(shù)
有時候我們想在Job執(zhí)行時需要一些參數(shù),并根據(jù)這些參數(shù)來做一些邏輯處理,這時候就需要使用Quartz傳參了。
在Quartz中傳參主要有一些幾種方式
1.job傳參
2.Trigger傳參
1.job傳參和Trigger傳參
使用JobDataMap.Add添加參數(shù),在job內部使用上下文的JobDataMap.GetString獲取
IJobDetail sendEmailJob = JobBuilder.Create<SendMailJob>().Build(); //往Job傳一個參數(shù) sendEmailJob.JobDataMap.Add("params","job測試傳參"); ITrigger trigger = TriggerBuilder.Create().Build(); //往trigger傳一個參數(shù) trigger.JobDataMap.Add("params", "trigger測試傳參"); //在job中獲取參數(shù) public async Task Execute(IJobExecutionContext context) { await Task.Run(() => { //獲取job傳參 string paramJob = context.JobDetail.JobDataMap.GetString("params"); //獲取Trigger傳參 string paramTrigger = context.Trigger.JobDataMap.GetString("params"); //doSomthing Console.WriteLine($"開始發(fā)送郵件{DateTime.Now}"); }); }
四、在scheduler中注冊監(jiān)聽器
監(jiān)聽器是為調度程序中發(fā)生的事件執(zhí)行操作而創(chuàng)建的對象,主要有一下三種監(jiān)聽器
1.調度監(jiān)聽器ISchedulerListener主要用于調度過程的監(jiān)聽。
2.觸發(fā)器監(jiān)聽器ITriggerListener主要用于接收和觸發(fā)器相關的事件監(jiān)聽。
3.作業(yè)監(jiān)聽器IJobListener用于接收Job運行生命周期相關事件監(jiān)聽。
1.實現(xiàn)監(jiān)聽器
以作業(yè)監(jiān)聽器為例,因為觸發(fā)和調度監(jiān)聽一樣的實現(xiàn)。
1.自定義作業(yè)監(jiān)聽器需要繼承自IJobListener接口并實現(xiàn)方法.
2.在調度器的監(jiān)聽管理中添加自定義監(jiān)聽器.
//實現(xiàn)監(jiān)聽器 public class CustomJobListener : IJobListener { public string Name => "CustomJobListener"; } //添加到監(jiān)聽管理中 scheduler.ListenerManager.AddJobListener(new CustomJobListener());
五、可視化管理界面
用于可視化工具來查看當前運行Job的信息。
1.需要新建一個web項目或者控制臺項目。
2.在web項目中 Nuget 引入Quartz 和CrystalQuartz.Remote程序包
3.在Job調度中配置StdSchedulerFactory相關信息指定監(jiān)聽端口
var properties = new NameValueCollection(); properties["quartz.scheduler.instanceName"] = "Test Monitor System"; // 設置線程池 properties["quartz.threadPool.type"] = "Quartz.Simpl.SimpleThreadPool, Quartz"; properties["quartz.threadPool.threadCount"] = "5"; properties["quartz.threadPool.threadPriority"] = "Normal"; // 遠程輸出配置 properties["quartz.scheduler.exporter.type"] = "Quartz.Simpl.RemotingSchedulerExporter, Quartz"; properties["quartz.scheduler.exporter.port"] = "8081"; properties["quartz.scheduler.exporter.bindName"] = "QuartzScheduler"; properties["quartz.scheduler.exporter.channelType"] = "tcp"; var schedulerFactory = new StdSchedulerFactory(properties); IScheduler _scheduler = await schedulerFactory.GetScheduler();
4.web監(jiān)控端去訪問統(tǒng)一的端口號下的CrystalQuartzPanel.axd即可查看。
六、配置文件配置任務
我們除了在代碼中定義任務的各種調度和觸發(fā)器之外,還可以使用xml配置文件的方式來創(chuàng)建Job任務
1.準備配置文件,配置Job+trigger相關信息,一定要將此文件屬性設為"始終復制"
<?xml version="1.0" encoding="UTF-8"?> <job-scheduling-data xmlns="http://quartznet.sourceforge.net/JobSchedulingData" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" version="2.0"> <processing-directives> <overwrite-existing-data>true</overwrite-existing-data> </processing-directives> <schedule> <job> <name>sendEmailJob</name> <group>Test Mail Job</group> <description>This is Test Mail Job</description> <!--此處為Job所在的類,及程序集--> <job-type>DispatcherProject.Job.SendMailJob,DispatcherProject</job-type> <durable>true</durable> <recover>false</recover> </job> <trigger> <cron> <name>sendEmailTrigger</name> <group>sendEmailJobGrop</group> <job-name>sendEmailJob</job-name> <job-group>Test Mail Job</job-group> <cron-expression>5/3 * * * * ?</cron-expression> </cron> </trigger> </schedule> </job-scheduling-data>
2.讀取配置文件,獲取信息,生成對應的Job和Trigger
XMLSchedulingDataProcessor processor = new XMLSchedulingDataProcessor(new SimpleTypeLoadHelper()); //讀取配置文件 await processor.ProcessFileAndScheduleJobs("~/config/quartz.xml", scheduler); //啟動調度任務 await scheduler.Start();
原文鏈接:https://www.cnblogs.com/yuxl01/p/15674125.html
相關推薦
- 2022-09-08 Go語言通道之無緩沖通道_Golang
- 2022-04-12 Cannot read property ‘forEach‘ of undefined
- 2022-07-07 圖解AVL樹數(shù)據(jù)結構輸入與輸出及實現(xiàn)示例_C 語言
- 2022-05-14 解決Linux未啟用網(wǎng)卡的問題_Linux
- 2022-09-23 WPF仿微信實現(xiàn)截圖功能的方法詳解_C#教程
- 2022-06-14 C#委托與冒泡排序實例_C#教程
- 2022-10-18 QT中QDataStream二進制數(shù)據(jù)讀寫的實現(xiàn)_C 語言
- 2023-01-11 基于Qt播放器的實現(xiàn)詳解(支持Rgb,YUV格式)_C 語言
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細win安裝深度學習環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結構-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支