Quartz.net 定时任务框架

  Quartz.net是一个从Java版的Quartz移植过来的定时任务框架,可以实现异常灵活的定时任务,开发人员编写很少的代码就可以实现“每隔1小时”、“每天22点执行”、“每月18日下午执行8次”等各种定时任务。


概念:

  三个概念:计划者(ISchedeler)、工作(IJob)、触发器(Trigger)。

  给计划者(Schedeler)一个工作(Job),让他在Trigger(某个条件)触发的条件下执行这个工作(Job)

  将要定时执行的任务代码写到实现IJob接口的Execute方法中即可使用,时间到来的时候Execute方法会被调用。


用法:

  ①VS在Nuget包中安装Quartz.net  

  ②定义一个实现IJob接口的类,把要定是执行的代码写到Execute方法中


IJob的Execute中异常问题:

  Job是运行在单独的线程中,因此如果Execute中如果发生异常,调试的时候是不会断点暂定的,好像什么都没有发生一样。如果运行在ASP.Net中,也不会出发ASP.net的“未处理异常处理程序”,就好像任务没执行一样。为了当出现异常的时候我们能及早发现,需要把Execute的代码try...catch...然后把异常处理(比如记录到日志)。


IJob中怎么样MapPath:

  由于Job是运行在单独的线程中,是拿不到HttpContext.Current的,那怎么MapPath呢?HostingEnvironment.MapPath()。(也不能再Job中做Request、Session等和Web相关的工作)


常用的几种定时模式:

  每周固定时间:CronScheduleBuilder.AtHourAndMinuteOnGivenDaysOfWeek(13,55,DayOfWeek.Friday,DayOfWeek.Sunday)//每周五、周日的13:55执行;

  每周固定时间:CronScheduleBuilder.WeeklyOnDayAndHourAndMinute();

  每月固定时间:CronScheduleBuilder.MonthlyOnDayAndHourAndMinute();

以上模式实现不了的:

  使用Crond表达式设定:CronSchedeleBuilder.CronSchedule("0 0 10 14 10 ? *")//每年的10月14日10:00执行

  只有你想不到的怎么定时,没有它做不到的。Crond表达式也不用记,参考网址:http://cron.qqe2.com/就可生成任何你想定的时间。


 

例子:

class TestJob : IJob//实现IJob接口
    {
        public void Execute(IJobExecutionContext context)//时间到来是调用的方法
        {
            //log4net.Config.XmlConfigurator.Configure();
            try
            {
                Console.WriteLine("任务执行啦" + DateTime.Now);
            }
            catch (Exception ex)
            {
                ILog log = LogManager.GetLogger(typeof(TestJob));
                log.Error("定时任务出错",ex);
            }
            
        }

    }
class Prog
    {
        public static void Main(string[] args)
        {
            IScheduler sched = new StdSchedulerFactory().GetScheduler();//定义计划者
            JobDetailImpl jbBossReport = new JobDetailImpl("jdTest", typeof(TestJob));//时间到来时,执行TestJob类中的context方法。同时给该执行任务命名为jdTest

            var builder = CalendarIntervalScheduleBuilder.Create();
            builder.WithInterval(3, IntervalUnit.Second);//每隔3秒执行
            IMutableTrigger triggerBossReport = builder.Build();//确定触发器

            triggerBossReport.Key = new TriggerKey("triggerTest");//触发器命名为triggerTest
            sched.ScheduleJob(jbBossReport, triggerBossReport);//计划者sched在触发器triggerBossReport执行的时候,进行jbBossReport工作。
            sched.Start();

            Console.WriteLine("OK");
            Console.ReadKey();
        }

    }

执行效果:


遇到一些复杂的任务无法通过Crond,比如“春节期间不提醒”:在Execute的开始检测一下时候允许执行,不允许执行的则直接return。

如果执行多个任务:执行者不用重新定义,触发器和工作直接在下边写即可,注意JobDetail和Trigger的名字不能重复。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值