我正在读关于调度的Spring 3.0 docs。我倾向于Spring的JobDetailBean for Quartz。但是@Scheduled注释引起了我的注意。看来这是使用Spring Framework调度任务的另一种方式。基于文档,Spring提供了三种调度方式:
我对JDK Timer没兴趣。我为什么要选择@Scheduled而不是Quartz? (当我提到Quartz时,我的意思是使用Spring的bean包装器进行Quartz)。
假设我的用例非常复杂,我将与第三方Web服务进行通信,以便按指定的时间间隔导入和导出数据。
Quartz比Spring的内置调度程序复杂一个数量级,包括对持久,事务和分布式作业的支持。尽管如此,即使使用Spring的API支持,它也有点像猪。
如果您需要的是每隔X秒或在cron时间表上对bean执行方法,那么@Scheduled
(或Spring的<task>
config schema中的各种选项)可能就足够了
我必须说明我自己在使用@Scheduled
和Quartz
作为Spring应用程序中的调度实现方面的经验。
调度作业具有以下要求:
因此,我们必须尝试使用Quartz实现(版本2.2.3)以支持数据库中作业的持久性。一些基本结论如下:
JobListener
和TriggerListener
在主数据库中维护一些有用的(以及更多面向用户的)有关用户定义的预定作业的信息。我们可以使用@Scheduler中不存在的更复杂的功能。例如:
scheduler.standby();
将调度程序置于待机模式,并使用scheduler.start();
重新安排它。scheduler.shutdown(true);
和scheduler.shutdown(false);
关闭调度程序
JobDetail job1 =newJob(MyJobClass.class). withIdentity("job1","group1"). storeDurably(). build();
JobDetail job1 = newJob(MyJobClass.class). withIdentity("job1", "group1"). build();
在Spring中,您可以使用FixedRate,FixedDelay和cron来安排任务。但是大多数预定作业需要动态处理执行时间。所以在这种情况下最好使用Quartz,因为它提供了在DBJobstore和RAMJobstore中存储预定作业的选项。