什么是定时任务?

什么是Quartz?

涉及知识点


Quartz安装

创建一个简单的定时器任务
using Quartz;using System.Diagnostics;namespace DemoQuartz.QuartzA.Job{/// <summary>/// 测试任务,实现IJob接口/// </summary>public class TestJob : IJob{public TestJob(){Console.WriteLine("执行构造函数");//表示每一次计划执行,都是一次新的实例}public Task Execute(IJobExecutionContext context){return Task.Run(() =>{Console.WriteLine($"******************************");Console.WriteLine($"测试信息{DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff")}");Console.WriteLine($"******************************");Console.WriteLine();});}}}
//创建计划单元(时间轴,载体)StdSchedulerFactory schedulerFactory = new StdSchedulerFactory();var scheduler = await schedulerFactory.GetScheduler();await scheduler.Start();
//Trigger时间触发机制var trigger = TriggerBuilder.Create().WithIdentity("TestTrigger","TestGroup")//.StartNow() //立即执行.WithSimpleSchedule(w=>w.WithIntervalInSeconds(5).WithRepeatCount(5))//.RepeatForever()//无限循环//.WithCronSchedule("5/10 * * * * ?") //通过Cron表达式定制时间触发规则, 示例表示从5开始,每隔10秒一次.Build();
//Job详细描述var jobDetail = JobBuilder.Create<TestJob>().WithDescription("这是一个测试Job").WithIdentity("TestJob", "TestGroup").Build();
//把时间和任务通过载体关联起来await scheduler.ScheduleJob(jobDetail, trigger);

传递参数
-
-
jobDetail.JobDataMap,工作描述时通过JobDataMap传递参数。 -
trigger.JobDataMap, 时间触发时通过JobDataMap传递参数。 -
在Job工作单元中,可以通过Context中对应的JobDataMap获取参数。
-
//传递参数jobDetail.JobDataMap.Add("name", "Alan");jobDetail.JobDataMap.Add("age", 20);jobDetail.JobDataMap.Add("sex", true);//trigger同样可以传递参数trigger.JobDataMap.Add("like1", "meimei");trigger.JobDataMap.Add("like2", "football");trigger.JobDataMap.Add("like3", "sing");
//获取参数var name = context.JobDetail.JobDataMap.GetString("name");var age = context.JobDetail.JobDataMap.GetInt("age");var sex = context.JobDetail.JobDataMap.GetBoolean("sex") ? "男" : "女";var like1 = context.Trigger.JobDataMap.GetString("like1");var like2 = context.Trigger.JobDataMap.GetString("like2");var like3 = context.Trigger.JobDataMap.GetString("like3");//context.MergedJobDataMap.GetString("aa");//注意如果使用MergedJobDataMap,JobDetail和Trigger中用到相同的Key,则后面设置的会覆盖前面设置的。
任务特性
-
-
[PersistJobDataAfterExecution]//在执行完成后,保留JobDataMap数据 -
[DisallowConcurrentExecution]//不允许并发执行,即必须等待上次完成后才能执行下一次
-
监听器
public class TestSchedulerListener : ISchedulerListener{public Task JobAdded(IJobDetail jobDetail, CancellationToken cancellationToken = default){return Task.Run(() => {Console.WriteLine("Test Job is added.");});}public Task JobDeleted(JobKey jobKey, CancellationToken cancellationToken = default){return Task.Run(() => {Console.WriteLine("Test Job is deleted.");});}public Task JobInterrupted(JobKey jobKey, CancellationToken cancellationToken = default){return Task.Run(() => {Console.WriteLine("Test Job is Interrupted.");});}public Task JobPaused(JobKey jobKey, CancellationToken cancellationToken = default){return Task.Run(() => {Console.WriteLine("Test Job is paused.");});}public Task JobResumed(JobKey jobKey, CancellationToken cancellationToken = default){return Task.Run(() => {Console.WriteLine("Test Job is resumed.");});}public Task JobScheduled(ITrigger trigger, CancellationToken cancellationToken = default){return Task.Run(() => {Console.WriteLine("Test Job is scheduled.");});}public Task JobsPaused(string jobGroup, CancellationToken cancellationToken = default){return Task.Run(() => {Console.WriteLine("Test Jobs is paused.");});}public Task JobsResumed(string jobGroup, CancellationToken cancellationToken = default){return Task.Run(() => {Console.WriteLine("Test Jobs is resumed.");});}public Task JobUnscheduled(TriggerKey triggerKey, CancellationToken cancellationToken = default){return Task.Run(() => {Console.WriteLine("Test Jobs is un schedulered.");});}public Task SchedulerError(string msg, SchedulerException cause, CancellationToken cancellationToken = default){return Task.Run(() => {Console.WriteLine("Test scheduler is error.");});}public Task SchedulerInStandbyMode(CancellationToken cancellationToken = default){return Task.Run(() => {Console.WriteLine("Test scheduler is standby mode.");});}public Task SchedulerShutdown(CancellationToken cancellationToken = default){return Task.Run(() => {Console.WriteLine("Test scheduler is shut down.");});}public Task SchedulerShuttingdown(CancellationToken cancellationToken = default){return Task.Run(() => {Console.WriteLine("Test scheduler is shutting down.");});}public Task SchedulerStarted(CancellationToken cancellationToken = default){return Task.Run(() => {Console.WriteLine("Test scheduleer is started.");});}public Task SchedulerStarting(CancellationToken cancellationToken = default){return Task.Run(() => {Console.WriteLine("Test scheduler is starting.");});}public Task SchedulingDataCleared(CancellationToken cancellationToken = default){return Task.Run(() => {Console.WriteLine("Test scheduling is cleared.");});}public Task TriggerFinalized(ITrigger trigger, CancellationToken cancellationToken = default){return Task.Run(() => {Console.WriteLine("Test trigger is finalized.");});}public Task TriggerPaused(TriggerKey triggerKey, CancellationToken cancellationToken = default){return Task.Run(() => {Console.WriteLine("Test trigger is paused.");});}public Task TriggerResumed(TriggerKey triggerKey, CancellationToken cancellationToken = default){return Task.Run(() => {Console.WriteLine("Test trigger is resumed.");});}public Task TriggersPaused(string? triggerGroup, CancellationToken cancellationToken = default){return Task.Run(() => {Console.WriteLine("Test triggers is paused.");});}public Task TriggersResumed(string? triggerGroup, CancellationToken cancellationToken = default){return Task.Run(() => {Console.WriteLine("Test triggers is resumed.");});}}
/// <summary>/// 触发器监听/// </summary>public class TestTriggerListener : ITriggerListener{public string Name => "TestTriggerListener";public Task TriggerComplete(ITrigger trigger, IJobExecutionContext context, SchedulerInstruction triggerInstructionCode, CancellationToken cancellationToken = default){//任务完成return Task.Run(() => {Console.WriteLine("Test trigger is complete.");});}public Task TriggerFired(ITrigger trigger, IJobExecutionContext context, CancellationToken cancellationToken = default){return Task.Run(() => {Console.WriteLine("Test trigger is fired.");});}public Task TriggerMisfired(ITrigger trigger, CancellationToken cancellationToken = default){return Task.Run(() => {Console.WriteLine("Test trigger is misfired.");});}public Task<bool> VetoJobExecution(ITrigger trigger, IJobExecutionContext context, CancellationToken cancellationToken = default){return Task.Run(() => {Console.WriteLine("Test trigger is veto.");return false;//是否终止});}}
/// <summary>/// TestJob监听器/// </summary>public class TestJobListener : IJobListener{public string Name => "TestJobListener";public Task JobExecutionVetoed(IJobExecutionContext context, CancellationToken cancellationToken = default){//任务被终止时return Task.Run(() => {Console.WriteLine("Test Job is vetoed.");});}public Task JobToBeExecuted(IJobExecutionContext context, CancellationToken cancellationToken = default){//任务被执行时return Task.Run(() => {Console.WriteLine("Test Job is to be executed.");});}public Task JobWasExecuted(IJobExecutionContext context, JobExecutionException? jobException, CancellationToken cancellationToken = default){//任务已经执行return Task.Run(() => {Console.WriteLine("Test Job was executed.");});}}
//增加监听scheduler.ListenerManager.AddJobListener(new TestJobListener());scheduler.ListenerManager.AddTriggerListener(new TestTriggerListener());scheduler.ListenerManager.AddSchedulerListener(new TestSchedulerListener());
日志管理
public class TestLogProvider : ILogProvider{public Logger GetLogger(string name){return (level, func, exception, parameters) =>{if (level >= Quartz.Logging.LogLevel.Info && func != null){Console.WriteLine("[" + DateTime.Now.ToLongTimeString() + "] [" + level + "] " + func(), parameters);}return true;};}public IDisposable OpenMappedContext(string key, object value, bool destructure = false){throw new NotImplementedException();}public IDisposable OpenNestedContext(string message){throw new NotImplementedException();}}
//日志LogProvider.SetCurrentLogProvider(new TestLogProvider());
完整示例

