一、分类

  1. Java自带的java.util.Timer类,这个类允许你调度一个java.util.TimerTask任务。使用这种方式可以让你的程序按照某一个频度执行,但不能在指定时间运行。

  2. 使用Quartz,这是一个功能比较强大的的调度器,可以让你的程序在指定时间执行,也可以按照某一个频度执行,配置起来稍显复杂。

  3. Spring3.0以后自带的task,可以将它看成一个轻量级的Quartz,而且使用起来比Quartz简单许多。


TimerTask:http://www.cnblogs.com/hongwz/p/5642320.html

Quartz:http://www.cnblogs.com/hongwz/p/5642429.html

spring-task:http://www.cnblogs.com/hongwz/p/5642497.html




Spring Quartz 和 Spring Task执行时间对比: 
1. Quartz设置同步模式时:一个任务的两次执行的时间间隔是:“执行时间”和“trigger的设定间隔”的最大值 
2. Task默认同步模式:一个任务的两次执行的时间间隔是:“执行时间”+“trigger的设定间隔”,即一个任务完成执行后,才开始trigger计时

Spring Quartz 特点: 
1. 默认多线程异步执行 
2. 一个任务在上一次调度未完成执行,下一次调度时间到时,会另起一个线程开始新的调度。在业务繁忙时,一个任务或许会有多个线程在执行,导致数据处理异常。 
3. 单任务同步:配置属性,可以使一个任务的一次调度在未完成时,而不会开启下一次调度 
4. 多个任务同时运行,任务之间没有直接的影响,多任务执行的快慢取决于CPU的性能 
5. SchedulerFactoryBean不能使用注解来配置?还是我没找到注解的方法?

6、有监听和插件功能、集群功能;

Spring Task特点: 
1. 默认单线程同步执行 
2. 一个任务执行完上一次之后,才会执行下一次调度 
3. 多任务之间按顺序执行,一个任务执行完成之后才会执行另一个任务 
4. 多任务并行执行需要设置线程池 
5. 全程可以通过注解配置



开源的分布式任务调度:saturn和Elastic-Job


https://github.com/vipshop/Saturn/wiki/Saturn-Amazing-Feature-Description#