开源的作业调度框架:Quartz.NET
2011-03-08 10:09
573 查看
Quartz.NET是一套开源的作业调度框架,是最初由Java平台的企业级开源作业调度框架 Quartz
移植到.NET平台的。在sourceforge上,Quartz.NET的主页有这样的介绍: Quartz.NET is a full-featured,
open source job scheduling system that can be used from smallest apps to large
scale enterprise systems.
(Quartz.NET是能应用在小到轻量级的应用程序,大到重量级的企业级系统中的全功能的开源任务调度系统)并且,值得令人信服的是,Quartz.NET已经在生产环境中得以用,并得到了良好的反馈。
回想一下,在小到普通的应用程序,大到企业级项目中,我们常常会遇到需要定时轮询和调度的场景,简单点的需求是每隔固定的秒数或者分钟、小时进行轮询,复杂点的是每周的某个时刻,或者每月,或者每年才执行一次,又或者更复杂的情景,某些天需要执行,某些天不执行。用Windows自带的计划任务,能够实现简单的逻辑,如果要用程序实现这样的逻辑,想必也很复杂了。其实,用Quartz能很好的应付这些情况。Quartz.NET的核心模块分为几个部分,Scheduler、Job、JobDetail、Trigger
Scheduler:实现调度的主体,负责调度任务的开始、结束,Scheduler中包含已注册的JobDetail和Trigger,并且,当Trigger中的条件得以触发时,Scheduler负责执行和Trigger相关联的Job,实现任务的调度。
Job:需要被调度的任务,Job必须实现IJob接口的Execute方法,而Execute方法的内容,其实也就是我们需要根据不同的需求自己实现的业务逻辑。
JobDetail:包含对Job的具体描述,包括Job的名称、所属的Group名称、以及Job的Type描述,用以Quartz.NET通过反射实现对Job的调用。
Trigger:触发器,描述调度的触发条件和时机。
Quartz.NET之所以没把Job和Trigger设计在一起,而是采用一种松耦合的方式,把Job和Trigger独立为两个不同的对象,原因是因为在Quartz.NET中,Job和Trigger可以建立一种一对多的关系,也就是可以对一个调度任务绑定多个Trigger,另外的好处是当某个Job的Trigger过期的时候,可以直接为Job绑定新的Trigger而不用重新定义和这个Trigger相关联的Job。
最初见到Quartz.NET,还是0.6的版本,一直躺在偶的硬盘里面,直到最近项目中遇到很多需要定时轮询处理的情况,突然想到了Quartz.NET,打开它在sourceforge的大本营,才发现Quartz.NET已经更新到1.0.1版本了。
Quartz.NET为我们提供了简洁的API,通过简单的例子,我们就可以很快上手和使用
在Quartz.NET中,所有的Job都必须实现IJob接口:
?[Copy to
clipboard]View Code CSHARP
1 2 3 4 5 6 7 | namespace Quartz { public interface IJob { void Execute(JobExecutionContext context); } } |
编写我们自己的Job,实现IJob接口:
?[Copy to
clipboard]View Code CSHARP
1 2 3 4 5 6 78 | using Quartz; namespace ExampleJob { public class TestJob : IJob { public void Execute(JobExecutionContext context) { Console.WriteLine("Job executed!"); } } } |
?[Copy to
clipboard]View Code CSHARP
1 2 3 4 5 6 78 | // 创建SchedulerFactory ISchedulerFactory schedFact = new StdSchedulerFactory(); // 获取Scheduler实例 IScheduler sched = schedFact.GetScheduler(); sched.Start(); // 创建JobDetail JobDetail jobDetail = new JobDetail("ExampleJob", "MyJobGroup", typeof(ExampleJob)); // 创建Trigger,每分钟触发一次 Trigger trigger = TriggerUtils.MakeMinutelyTrigger(); // 设定trigger的开始时间 trigger.StartTimeUtc = TriggerUtils.GetEvenHourDate(DateTime.UtcNow); trigger.Name = "myTrigger"; sched.ScheduleJob(jobDetail, trigger); |
其实Quartz.NET还有很多方便开发人员的特性和高级功能,比如通过配置文件配置Job和Trigger,可以让你的调度程序更加灵活,以应对后续需求的变化,而不需要重新编译程序。另外,还有调度线程池、JobStore、Clustering等很多高级功能,等着我们去发现。
相关资源:
Quartz.NET 主页:http://quartznet.sourceforge.net
在sourceforge的Quartz.NET主页上,有入门教程供初学者查看:http://quartznet.sourceforge.net/tutorial/index.html
另外,博客园的张善友也把教程翻译成了中文的,供E文不好的同学学习和参考,地址:/article/4588630.html
相关文章推荐
- 开源的作业调度框架 - Quartz.NET
- 开源的作业调度框架 - Quartz.NET
- Quartz.NET开源作业调度框架系列(二):CronTrigger
- 开源作业调度框架 - Quartz.NET - Cron表达式测试
- (转).Net平台开源作业调度框架Quartz.Net
- .Net平台开源作业调度框架Quartz.Net
- 开源的作业调度框架 - Quartz.NET
- 开源作业调度框架 - Quartz.NET - 实战使用1
- Quartz.NET(开源的作业调度框架)使用
- .Net平台开源作业调度框架Quartz.Net
- Quartz.NET一个开源的作业调度框架
- Quartz.NET开源作业调度框架系列(五):AdoJobStore保存job到数据库
- Quartz.NET开源作业调度框架系列(五):AdoJobStore保存job到数据库
- 开源的作业调度框架 - Quartz.NET
- 开源的作业调度框架 - Quartz.NET
- 开源的作业调度框架 - Quartz.NET
- 开源的作业调度框架 - Quartz.NET
- 开源的作业调度框架 - Quartz.NET
- 开源的作业调度框架 - Quartz.NET
- 开源的作业调度框架 - Quartz.NET 推荐