当前位置: 首页 > news >正文

C# Quartz.net 定时任务

Quartz.net 定时任务

  • 官网
    • 安装
    • 主要成员
      • Job
      • Trigger
      • eduler
    • 示例:
    • Scheduler简介
    • 框架核心接口
    • Job
    • Trigger
    • JobDataMap
      • 示例代码如下:
      • Trigger
        • 示例代码如下

官网

https://www.quartz-scheduler.net/documentation/quartz-3.x/how-tos/one-off-job.html

安装

install-package quartz

主要成员

Job

Job是具体的业务逻辑所在,是定时任务中要执行的那一项任务

Trigger

Trigger触发器,规定了定时任务的执行时间、频率、次数

eduler

Scheduler调度器将Job和Trigger关联起来,负责整个定时任务的开启、关闭

示例:

class Program{public static async Task Main(string[] args){ISchedulerFactory schedulerFactory = new StdSchedulerFactory();IScheduler scheduler=await schedulerFactory.GetScheduler();//创建schedulerawait scheduler.Start();//启动schedulerIJobDetail job = JobBuilder.Create<TestJob>().WithIdentity("testJob", "testGroup").Build();//创建job(jobdetail)ITrigger trigger = TriggerBuilder.Create().WithIdentity("testTrigger", "testGroup").StartNow().WithSimpleSchedule(x=>x.WithIntervalInSeconds(10).RepeatForever()).Build();//创建trigger 现在开始 每10秒执行一次  无限重复await scheduler.ScheduleJob(job, trigger);//scheduler关联trigger和jobConsole.ReadLine();}}public class TestJob : IJob{public async Task Execute(IJobExecutionContext context){//定时job的执行内容await Task.Run(()=>{ Debug.WriteLine("testJob");});}}

Scheduler简介

官方提供了实现类StdSchedulerFactory

实例化一个Scheduler以后,Scheduler可以:

Start:开始定时任务,定时触发任务执行

待机:暂停,触发器也不会启动

Shutdown:停止调度器,不会在定时触发执行任务

框架核心接口

  • IScheduler 操作Scheduler的核心api。
  • IJob 业务逻辑所在地!要实现接口的Excute方法。
  • IJobDetail 用来实例化Job的!
  • ITrigger 一个job可以对应多个trigger,但是一个trigger只能对应一个job!所有trigger都实现该接口。
  • JobBuilder 用来创建JobDetail实例(JobDetail再创建Job实例)。
  • TriggerBuilder 用来创建Trigger实例。而且我们可以看到示例代码中的方法级联(流式接口)。
  • SchedulerBuilder 用来创建Scheduler实例。

Job

定时任务只需要继承IJob就可以了,然后必须要实现Execute方法

public class TestJob : IJob{public async Task Execute(IJobExecutionContext context){await Task.Run(()=>{ Debug.WriteLine("testJob");});}}

Trigger

Trigger可以包含JobDataMap参数,最常用的Trigger是

  1. SimpleTrigger (实现ISimpleTrigger接口)包含常用的方法,常用的定时任务大都可以实现

  2. CronTrigger (实现ICronTrigger接口) 主要是可以使用Cron表达式,来实现复杂的触发方式(当然简单的也可以)

JobDataMap

IJobDetail有一个JobDataMap属性,可以用来往Job里面传参。

设置参数:IJobDetail的UsingJobData

获取参数:IJobExecutionContext的JobDetail.JobDataMap属性的GetString(GetInt等等)方法

示例代码如下:

 class Program{public static async Task Main(string[] args){ISchedulerFactory schedulerFactory = new StdSchedulerFactory();IScheduler scheduler=await schedulerFactory.GetScheduler();await scheduler.Start();IJobDetail job = JobBuilder.Create<TestJob>().WithIdentity("testJob", "testGroup").UsingJobData("stringParam","hello job").UsingJobData("numberParam",2020).Build();ITrigger trigger = TriggerBuilder.Create().WithIdentity("testTrigger", "testGroup").StartNow().WithSimpleSchedule(x=>x.WithIntervalInSeconds(10).RepeatForever()).Build();await scheduler.ScheduleJob(job, trigger);Console.ReadLine();}}public class TestJob : IJob{public async Task Execute(IJobExecutionContext context){JobDataMap jobParam= context.JobDetail.JobDataMap;string paramStr= jobParam.GetString("stringParam");int paramNo = jobParam.GetInt("numberParam");await Console.Out.WriteLineAsync("paramStr=" + paramStr + ",paramNo=" + paramNo);}}

Trigger

Trigger也可以使用UsingJobData,使用场景是:

多个Trigger来触发同一个Job,不同的Trigger需要传不同的参数

示例代码如下
class Program{public static async Task Main(string[] args){ISchedulerFactory schedulerFactory = new StdSchedulerFactory();IScheduler scheduler=await schedulerFactory.GetScheduler();await scheduler.Start();IJobDetail job = JobBuilder.Create<TestJob>().WithIdentity("testJob", "testGroup").Build();ITrigger trigger = TriggerBuilder.Create().WithIdentity("testTrigger", "testGroup").UsingJobData("stringParam", "hello trigger").UsingJobData("numberParam", 2021).StartNow().WithSimpleSchedule(x=>x.WithIntervalInSeconds(10).RepeatForever()).Build();await scheduler.ScheduleJob(job, trigger);Console.ReadLine();}}public class TestJob : IJob{public async Task Execute(IJobExecutionContext context){JobKey key = context.JobDetail.Key;//测试获取JobDetail的JobKey(JobBuilder设置的)JobDataMap jobParam = context.MergedJobDataMap;//获取Trigger设置的JobDataMapstring paramStr= jobParam.GetString("stringParam");int paramNo = jobParam.GetInt("numberParam");await Console.Out.WriteLineAsync("key="+key+",paramStr=" + paramStr + ",paramNo=" + paramNo);//key=testGroup.testJob,paramStr=hello trigger,paramNo=2021}}
http://www.lryc.cn/news/573706.html

相关文章:

  • Python 数据分析与可视化 Day 4 - Pandas 数据筛选与排序操作
  • Maven生命周期,测试
  • Python期末速成
  • Flink图之间流转解析:从逻辑构建到物理执行的深度剖析
  • 集群聊天服务器---muduo库的使用
  • 无锡哲讯科技:助力纺织业搭乘 SAP 数字化快车
  • 颠覆传统接口测试!用 Streamlit + SQLite + GPT 打造可视化自动化平台
  • Linux安全基石:Shell运行原理与权限管理系统解读
  • 企业级安全实践:SSL 加密与权限管理(二)
  • 设计模式精讲 Day 10:外观模式(Facade Pattern)
  • Java面试复习:基础、面向对象、多线程、JVM与Spring核心考点
  • 药房智慧化升级:最优成本条件下开启地市级医院智慧医疗新变革
  • c#多线程中的字典键值对象ConcurrentDictionary线程安全
  • 《HTTP权威指南》 第14章 安全HTTP
  • 【JS-4.4-键盘常用事件】深入理解DOM键盘事件:提升用户交互体验的关键
  • “MOOOA多目标鱼鹰算法在无人机多目标路径规划
  • leetcode:面试题 08.01. 三步问题
  • Linux 无线网络驱动开发 之 子系统源码框架(nl80211、cfg80211、mac80211)
  • 【weaviate】分布式数据写入之LSM树深度解析:读写放大的权衡
  • 计算机网络通信技术与协议(九)————交换机技术
  • flink如何支持kafka容灾自动切换
  • C++,Qt事件处理机制编程开发练习全解析,23000字解析!!
  • 二、Generative adversarial network (GAN)
  • 深入理解Spring MVC:构建灵活Web应用的基石
  • Elasticsearch Kibana (一)
  • React纯函数和hooks原理
  • 开发语言本身只是提供了一种解决问题的工具
  • Qt应用中处理Linux信号:实现安全退出的技术指南
  • 对射式红外传感器计次旋转编码器计次
  • 消息队列:基本知识