任何个人、任何企业、任何行业都会有作业调度的需求。举几个简单的例子:
1、每个月都会发工资,每个月都要报销等;
2、每个人每天都要吃饭和睡觉;
3、每个公司都有会计帐期,都需要向公司领导汇报月报、季报、年报等。
4、银行和金融行业每天都需要日切等等。
对于个人,对作业调度的感知不是非常明确,但对于一个企业,一个好的作业调度可以为企业节省很多时间和金钱。俗话说,时间就是金钱,过高的资源投入到枯燥的任务中无疑是金钱和资源的浪费,随着业务流程复杂性的提高,自动化流程和自动化作业调度更能凸显出益处来。之所以自动化的出现,因为在做重复性工作时,人的效率和正确率远低于电脑。把一系列任务自动安排到一个作业中,然后再为这个作业创建一个调度器,到时候这个作业就会自动执行了。
Quartz是经典的作业调度框架,在深入研究之初,先仿照quartz的原理,设计一个简单的作业调度器,类图如下:
1、 先看job类,这个类,非常简单,只有一个execute方法,该方法是job具体执行的内容:
2、 jobdetail类,该类是对具体job类的封装,包括jobName(id),job执行需要的运行时参数,在名为jobdata的hashMap中
3、 trigger类,记录下次运行作业的时间和运行job的key:
4、 scheduler类,最重要的类,用来启动和停止框架
5、 scheduler的执行是在scheduler的schedulerThread中执行;线程中最重要的是run方法体,另外还有一个halt方法用来停止线程。先看halt方法
Run方法体为:
至此所有的框架代码都已经完成。注:没有考虑NullPointException和多线程问题。
再看下测试代码:
结果
系统按照下次运行时间来执行,并成功显示结果。
本章只是在抽取quartz的核心处理逻辑的基础智商,去除安全验证和多线程同步问题编写的基本调度任务。仅为抛砖引玉,为quartz源码的解析打个基础。