作业调度系统quartz.net

  任务调度在我们日常开发过程中非常常见,比如:每天晚上0点自动执行某某操作;每周三晚上2点执行某某操作;......当然,我们处理这类问题的方法也有很多,比如:sql的自动任务;windows上创建任务计划;写windows服务等等。如果系统比较复杂,相互调用比较频繁,任务非常多,几百上千条甚至上万条,那么本身对任务的管理就是比较昂贵的代价;如何提高任务的高可用?任务的测试是否便捷等等问题就会出现。上述的方案是否还能从容应对?

        这时我们就迫切地需要一个作业调度系统来处理这些场景。

        Quartz.NET是一个强大、开源、轻量的作业调度框架,是 OpenSymphony 的 Quartz API 的.NET移植,它有很多特征,如:数据库支持,集群,插件,支持cron-like表达式等等。官方网址:

        2、新建一个类RemoteServerExample,主要代码:

3、新建一个类RemoteClientExample,主要代码:

4、SimpleJob代码:

5、程序运行界面:

点击启动调度器,启动服务器监听且默认有一个名为remotelyAddedJob的job,并且允许远程管理;点击添加任务,会加入一个名为remotelyAddedJob1的job;删除任务会删除所有job。

如果我们已经启动了调度器,有一个任务,比如,我们用TopShelf和quartz.net写了一个windows服务,在本地运行,如果要加入到远程管理中,怎么办呢?

可以按照上述RemoteClientExample代码,配置properties,调用的时候通过反射的方式获取,然后加入到调度器中,进行远程管理。

quartz.net还有持久化、集群等等特性,提高任务的高可用。

分享一个corn表达式生成器:https://files.cnblogs.com/files/net-yuan/CronExpBuilder.zip

大神张善友 的quartz.net系列:https://www.cnblogs.com/shanyou/category/102991.html

GitHub:https://github.com/anangyang/TaskSchedulinghttps://www.cnblogs.com/net-yuan/p/quartz.html

50000+
5万行代码练就真实本领
17年
创办于2008年老牌培训机构
1000+
合作企业
98%
就业率

联系我们

电话咨询

0532-85025005

扫码添加微信