转载

开源任务管理平台TaskManager介绍

很早之前准备写Quartz系列文章,现在终于能够实现了。从本篇开始将带你实现一款自己的任务管理平台。在工作中你曾经需要应用执行一个任务吗?这个任务每天或每周星期二晚上11:30,或许仅仅每个月的最后一天执行。一个自动执行而无须干预的任务在执行过程中如果发生一个严重错误,应用能够知到其执行失败并尝试重新执行吗?你和你的团队是用.NET编程吗?如果这些问题中任何一个你回答是,那么你应该使用Quartz.NET调度器。

阅读目录

  • Quart.Net介绍
  • Cron表达式
  • 开源TaskManager实现原理
  • 使用介绍
  • 总结

回到顶部

Quartz.NET介绍

Quartz.NET是一个开源的作业调度框架,是OpenSymphony 的 Quartz API的.NET移植,它用C#写成,可用于winform和asp.net应用中。它提供了巨大的灵活性而不牺牲简单性。你能够用它来为执行一个作业而创建简单的或复杂的调度。它有很多特征,如:数据库支持,集群,插件,支持cron-like表达式等等。下载地址: Quart.Net

举个实际例子:现在需要实现一款快递进度查询的应用,我们肯定是没有各个快递厂商的数据库的,只能利用厂商提供的API接口来获取数据。好在现在有很多现成的接口集成了各厂商,基于这些基础。现在客户提了一个需求,在快递单进度发生改变时,给我发邮件或者短信提醒。我想很多网上购物的朋友都有这种需求吧,买了一款东西,时不时的查一下进度,期待早点到。那么这个提醒功能就很迫切了,我也是基于自己的这个需求来做的TaskManager开源项目。

回到顶部

Cron表达式

Cron表达式是用来指定任务执行频率的,前面我已经写了一篇 Quartz Cron表达式 在线生成器 的文章,大家可以直接拿来使用。

回到顶部

开源TaskManager介绍及实现原理

TaskManager是基于Quartz.NET的一款开源任务管理系统,使用Window服务来承载。目前系统集成了三个常用任务,代理IP爬虫,快递进度,消息通知。

代理IP爬虫:每隔一小时从网站上爬取最新的代理IP信息,爬下来的数据存在p_IPProxy表,有了这些代理IP以后,可以用来做投票机,刷接口之类的应用了。相信你肯定遇到过同学或同事发给你一个链接让你帮忙给XX投个票之类的问题,但是呢很多投票都限制了一个IP只能投一票,那么有了许多代理IP你就可以实现一个人投N票了。关于使用代理IP请求接口获取数据的实例,将在下一篇文章为大家介绍。

开源任务管理平台TaskManager介绍

快递进度:这对热衷于网购的朋友来说是一大福音,当然对我来说也是如此。经常网购的朋友最大的困扰可能就是我的快递到哪儿啦,时不时打开客户端查一下快递进度,要是有快递进度改变能够发短信或者邮件提醒的功能就好了,我就再也不用着急查快递到哪儿了。来看一下邮件提醒效果,有没有很激动,很想使用这个开源TaskManager平台啦!

开源任务管理平台TaskManager介绍

   消息通知:消息通知相关表p_Message(待发送消息表),p_MessageHistory(已发送或者发送失败消息表)

目前快递任务有信息变更会插入一条消息,消息通知任务3分钟轮询一次p_Message表,对于每个消息最多会进行三次发送(前两次都失败),发送完成将p_Message数据插入到p_MessageHistory

   项目结构介绍:项目是基于Quartz.NET的windows服务,目前包含六个项目

   开源任务管理平台TaskManager介绍

系统原理解析:

开源任务管理平台TaskManager介绍

开发模式:

添加一个新任务步骤如下

1.在Mysoft.Task项目TaskSet文件夹下添加继承IJob接口的任务类,可以参照现有的IpProxyJob

开源任务管理平台TaskManager介绍

2.修改TaskConfig.xml配置文件

开源任务管理平台TaskManager介绍

最重要的部分运行频率CronExpressionString需要怎么写?这里也替大家考虑到了,可以使用在线Cron生成器来生成,地址 http://jason.hahuachou.com/cron/index.htm ,也可以使用源代码里面提供的Cron自己部署站点使用。

回到顶部

使用介绍

介绍完了功能和实现原理,现在介绍怎么使用TaskManager。由于是使用Windows服务做为承载器,那么我们只需要知道怎么安装Windows服务,也就能使用该平台了。这里考虑到很多人不知道怎么安装卸载Windows服务,所以提供了我之前写的一个小工具Windows服务安装卸载。源代码也一起放在了TaskManager里面。

1.右键以管理员方式运行Windows安装卸载工具

2.选择TaskManger.exe-》安装-》运行

开源任务管理平台TaskManager介绍

运行成功以后可以在系统管理-》服务 里面找到“定时任务管服务”

开源任务管理平台TaskManager介绍

运行成功后会生成Logs文件夹,记录执行日志的

开源任务管理平台TaskManager介绍

当然在使用系统时你需要进行相关配置,下面讲一下配置过程。系统的配置文件路径Config/Config.xml 开源任务管理平台TaskManager介绍

1.数据库连接信息

使用者可以拿从SVN下载代码MyDocument项目下的任务系统”SQL合并脚本_20150911.sql”执行创建相关表和初始数据

修改节点SqlConnect节点的值为你自己的数据库连接

2.插入快递单模拟数据

目前使用快递任务需要自己手工插入快递单号信息

INSERT INTO dbo.p_ExpressInfo(ExpressNo,ExpressCompanyCode,Receiver) SELECT '880350384879600241' AS ExpressNo,'yuantong' AS ExpressCompanyCode,'youemial@xx.com' AS Receiver

其中youemail@xx.com为接收进度信息变更邮箱地址,只要有进度变更,系统会自动发邮件, 记得修改成自己的邮箱地址 

ExpressNo:为快递单号

 ExpressCompanyCode :快递公司Code  该值可从p_ExpressCompany表里面进行查询

开源任务管理平台TaskManager介绍

更多使用说明可以参考MyDocument项目下的 使用说明.docx 文档

回到顶部

总结

本篇要介绍的内容到此结束了,下面写点我的期待!希望有喜欢的朋友一起来完善TaskManager(完全开源的),使之成为一款能够提高生活便捷性的工具,添加很多新任务。比如:第二天要下雨或者下雪,发个邮件提醒,带上雨伞...。好了到了放出源代码的时间了。敬请期待下一篇!

TaskManagerSVN地址: http://code.taobao.org/svn/TaskManagerPub/Branch 使用svn checkout指令进行下载。

体验工具下载地址:TaskManager解压后文件如下,修改Config.xml数据库连接,使用WSWinForm进行安装。

开源任务管理平台TaskManager介绍

如果,您认为阅读这篇博客让您有些收获,不妨点击一下右下角的 【 推荐 】 按钮。

如果,您希望更容易地发现我的新博客,不妨点击一下绿色通道的 【 关注我 】 。

因为,我的写作热情也离不开您的肯定支持。

感谢您的阅读,如果您对我的博客所讲述的内容有兴趣,请继续关注我的后续博客,我是焰尾迭 。

正文到此结束
Loading...