您的位置:首页 > 其它

一句话带你听懂什么是Quartz

2016-06-10 14:03 302 查看
什么是Quartz
Quartz是一个开源的作业调度框架,由java编写,在.NET平台为Quartz.Net,通过Quart可以快速完成任务调度的工作.

Quartz能干什么/应用场景
如网页游戏中挂机自动修炼如8个小时,人物相关数值进行成长,当使用某道具后,时间减少到4个小时,人物对应获得成长值.这其中就涉及到了Scheduler的操作,定时对人物进行更新属性操作,更改定时任务执行时间.
网页游戏中会大量涉及到Scheduler的操作,有兴趣的朋友可自行联想.
企业中如每天凌晨2点触发数据同步、发送Email等操作

同类框架对比
TimeTask TimeTask在Quartz前还是显得过于简单、不完善,不能直接满足开发者的较为复杂的应用场景.

资源
官网:http://www.quartz-scheduler.org/
下载:http://www.quartz-scheduler.org/downloads
maven pom
<dependency>

    <groupId>org.quartz-scheduler</groupId>

    <artifactId>quartz</artifactId>

    <version>2.2.1</version>

</dependency>

<dependency>

    <groupId>org.quartz-scheduler</groupId>

    <artifactId>quartz-jobs</artifactId>

    <version>2.2.1</version>

</dependency>

源代码 svn:http://svn.terracotta.org/svn/quartz
本文章采用的是2.21版本:CSDN下载:http://download.csdn.net/detail/chenweitang123/7636703
例子Demo:CSDN下载:整理完后上传.

框架分析
接口
类图

Quartz中的设计模式
Builder模式
所有关键组件都有Builder模式来构建  <Builder> 如:JobBuilder、TriggerBuilder

Factory模式
最终由Scheduler的来进行组合各种组件  <Factory> 如SchedulerFactory

Quartz项目中大量使用组件模式,插件式设计,可插拔,耦合性低,易扩展,开发者可自行定义自己的Job、Trigger等组件
链式写法,Quartz中大量使用链式写法,与jQuery的写法有几分相似,实现也比较简单,如:
 $(this).addClass("divCurrColor").next(".divContent").css("display","block");  

[align=left]newTrigger().withIdentity( "trigger3", "group1").startAt( startTime)[/align]
[align=left]        .withSchedule(simpleSchedule().withIntervalInSeconds(10).withRepeatCount(10)).build();[/align]

框架核心分析
SchedulerFactory    -- 调度程序工厂
StdSchedulerFactory   -- Quartz默认的SchedulerFactory
DirectSchedulerFactory  --   DirectSchedulerFactory是对SchedulerFactory的直接实现,通过它可以直接构建Scheduler、threadpool 等
ThreadExecutor / DefaultThreadExecutor   -- 内部线程操作对象

JobExecutionContext -- JOB上下文,保存着Trigger、 JobDeaitl 等信息,JOB的execute方法传递的参数就是对象的实例
JobExecutionContextImpl

Scheduler    -- 调度器
StdScheduler    -- Quartz默认的Scheduler
RemoteScheduler  -- 带有RMI功能的Scheduler

JOB --任务对象
JobDetail  -- 他是实现轮询的一个的回调类,可将参数封装成JobDataMap对象,Quartz将任务的作业状态保存在JobDetail中.
JobDataMap --  JobDataMap用来报错由JobDetail传递过来的任务实例对象

Trigger
SimpleTrigger <普通的Trigger> --  SimpleScheduleBuilder
CronTrigger  <带Cron Like 表达式的Trigger> -- CronScheduleBuilder
CalendarIntervalTrigger <带日期触发的Trigger> -- CalendarIntervalScheduleBuilder
DailyTimeIntervalTrigger <按天触发的Trigger> -- DailyTimeIntervalScheduleBuilder

ThreadPool  --  为Quartz运行任务时提供了一些线程
SimpleThreadPool  --一个Quartz默认实现的简单线程池,它足够健壮,能够应对大部分常用场景

-----以上是Quartz涉及到的一些关键对象,详细的内容如有机会会在后续的文章中展开!

Quartz类图



类图中主要分为5块:Factory、Bulider、Scheduler、Trigger、JOB

思想

[java] view
plain copy

// 1、工厂模式 构建Scheduler的Factory,其中STD为Quartz默认的Factory  

//    开发者亦可自行实现自己的Factory;Job、Trigger等组件  

SchedulerFactory sf = new StdSchedulerFactory();  

  

// 2、通过SchedulerFactory构建Scheduler对象  

Scheduler sched = sf.getScheduler();  

  

// 3、org.quartz.DateBuilder.evenMinuteDate  -- 通过DateBuilder构建Date  

Date runTime = evenMinuteDate( new Date());  

  

// 4、org.quartz.JobBuilder.newJob <下一分钟> --通过JobBuilder构建Job  

JobDetail job = newJob(HelloJob.class).withIdentity("job1","group1").build();  

  

// 5、通过TriggerBuilder进行构建Trigger  

Trigger trigger = newTrigger().withIdentity("trigger1","group1")  

            .startAt(runTime).build();  

  

// 6、工厂模式,组装各个组件<JOB,Trigger>  

sched.scheduleJob (job, trigger);  

  

// 7、start   

sched.start();  

  

try {  

  Thread.sleep(65L * 1000L);  

} catch (Exception e) {  

}  

  

// 8、通过Scheduler销毁内置的Trigger和Job  

sched.shutdown(true);  

一句话看懂Quartz

[align=left]   1、创建调度工厂();    //工厂模式[/align]
[align=left]   2、根据工厂取得调度器实例();  //工厂模式[/align]
[align=left]   3、Builder模式构建子组件<Job,Trigger>  // builder模式, 如JobBuilder、TriggerBuilder、DateBuilder[/align]
[align=left]   4、通过调度器组装子组件   调度器.组装<子组件1,子组件2...>  //工厂模式[/align]
[align=left]   5、调度器.start(); //工厂模式[/align]



顶13
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: