建立定时执行任务的方法有很多,如果是Window系统,可以建立“任务计划程序”。如果是SQL Server数据库,可以创建“作业”。还可以建立一个Window Service,设置一个定时线程来实现。今天讨论的Quartz.Net是一款开源的作业调度框架,它可以在配置文件中设置定时调度的时间间隔,可以实现作业和触发器之间的多对多关联,可以重用作业。现在介绍Quartz.Net和Windows服务实现定时任务的功能。
(1)创建一个Windows服务
用VS创建一个Windows服务,把服务名称改为QService
(2)创建Quartz作业
使用NuGet安装Quartz
创建一个TestJob的类,继承IJob接口。在Execute里面就可以写作业的内容了。这里写一条日志,记录执行时间。
配置quartz_jobs.xml文件。
配置触发器有两种方法:
用<simple>直接设置循环执行的时间,计算单位用毫秒。repeat-count设置为-1的时候,表示会一直循环。
cron方法,主要配置start-time和cron-expression表达式。
无论是用哪一种方法,job-name和job-group都要与<job>里面的name和group对应。
job-type的内容要与你所编写的Job的命名空间对应。
(3)编写Windows服务
Quartz的配置文件在Service创建的时候加载
(4)查看结果
安装并启动Windows服务后,过两分钟把它停止
查看日志可以看到我们刚才创建的Job的执行情况。
Quartz.Net只是实现定时任务的其中一种方法。它不能解决任何问题。要使用哪一种方式实现定时任务,要根据具体的情况来确定。我见到过有人使用Quartz来做非常巨大的数据处理,而他的服务器配置很低,最后频繁出现内存溢出、服务器挂掉的问题。最后还说是Quartz.Net的扩展性不好,真是令人很无语。这种大规模的数据处理,使用数据库的定时作业是最好的办法了。定时任务不是非要使用某一种方法,可以组合实现。世上没有银弹,解决问题要结合现实的情况。