一、分类
Java自带的java.util.Timer类,这个类允许你调度一个java.util.TimerTask任务。使用这种方式可以让你的程序按照某一个频度执行,但不能在指定时间运行。
使用Quartz,这是一个功能比较强大的的调度器,可以让你的程序在指定时间执行,也可以按照某一个频度执行,配置起来稍显复杂。
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#
转载于:https://blog.51cto.com/gudaoqing/1924190