下面给出一些表达式实例:
|
表示式 |
说明 |
|
"0 0 12 * * ? " |
每天12点运行 |
|
"0 15 10 ? * *" |
每天10:15运行 |
|
"0 15 10 * * ?" |
每天10:15运行 |
|
"0 15 10 * * ? *" |
每天10:15运行 |
|
"0 15 10 * * ? 2008" |
在2008年的每天10:15运行 |
|
"0 * 14 * * ?" |
每天14点到15点之间每分钟运行一次,开始于14:00,结束于14:59。 |
|
"0 0/5 14 * * ?" |
每天14点到15点每5分钟运行一次,开始于14:00,结束于14:55。 |
|
"0 0/5 14,18 * * ?" |
每天14点到15点每5分钟运行一次,此外每天18点到19点每5钟也运行一次。 |
|
"0 0-5 14 * * ?" |
每天14:00点到14:05,每分钟运行一次。 |
|
"0 10,44 14 ? 3 WED" |
3月每周三的14:10分到14:44,每分钟运行一次。? |
|
"0 15 10 ? * MON-FRI" |
每周一,二,三,四,五的10:15分运行。 |
|
"0 15 10 15 * ?" |
每月15日10:15分运行。 |
|
"0 15 10 L * ?" |
每月最后一天10:15分运行。 |
|
"0 15 10 ? * 6L" |
每月最后一个星期五10:15分运行。 |
|
"0 15 10 ? * 6L 2007-2009" |
在2007,2008,2009年每个月的最后一个星期五的10:15分运行。 |
|
"0 15 10 ? * 6#3" |
每月第三个星期五的10:15分运行。 |
任务调度信息存储
在默认情况下Quartz将任务调度的运行信息保存在内存中,这种方法提供了最佳的性能,因为内存中数据访问最快。不足之处是缺乏数据的持久性,当程序路途停止或系统崩溃时,所有运行的信息都会丢失。
其实Quartz JAR文件的org.quartz包下就包含了一个quartz.properties属性配置文件并提供了默认设置。如果需要调整默认配置,可以在类路径下建立一个新的quartz.properties,它将自动被Quartz加载并覆盖默认的设置。
解析配置文件:
①集群的配置,这里不使用集群
org.quartz.scheduler.instanceName = DefaultQuartzScheduler
org.quartz.scheduler.rmi.export = false
org.quartz.scheduler.rmi.proxy = false
org.quartz.scheduler.wrapJobExecutionInUserTransaction = false
②配置调度器的线程池
org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPool
org.quartz.threadPool.threadCount = 10
org.quartz.threadPool.threadPriority = 5
org.quartz.threadPool.threadsInheritContextClassLoaderOfInitializingThread = true
③配置任务调度现场数据保存机制
org.quartz.jobStore.class = org.quartz.simpl.RAMJobStore
如果需要修改,使用数据库保存任务调度现场数据
org.quartz.jobStore.class = org.quartz.impl.jdbcjobstore.JobStoreTX
org.quartz.jobStore.tablePrefix = QRTZ_ ①数据表前缀
org.quartz.jobStore.dataSource = qzDS ②数据源名称
③定义数据源的具体属性
org.quartz.dataSource.qzDS.driver = oracle.jdbc.driver.OracleDriver
org.quartz.dataSource.qzDS.URL = jdbc:oracle:thin:@localhost:1521:ora9i
org.quartz.dataSource.qzDS.user = stamen
org.quartz.dataSource.qzDS.password = abc
org.quartz.dataSource.qzDS.maxConnections = 10
注意:
如果你使用JDBC保存任务调度数据时,当你运行代码清单2的SimpleTriggerRunner然后退出,当再次希望运行SimpleTriggerRunner时,系统将抛出JobDetail重名的异常:
因为每次调用Scheduler#scheduleJob()时,Quartz都会将JobDetail和Trigger的信息保存到数据库中,如果数据表中已经同名的JobDetail或Trigger,异常就产生了。
小结
Quartz提供了最为丰富的任务调度功能,不但可以制定周期性运行的任务调度方案,还可以让你按照日历相关的方式进行任务调度。Quartz框架 的重要组件包括Job、JobDetail、Trigger、Scheduler以及辅助性的JobDataMap和SchedulerContext。
Quartz拥有一个线程池,通过线程池为任务提供执行线程,你可以通过配置文件对线程池进行参数定制。Quartz的另一个重要功能是可将任务调 度信息持久化到数据库中,以便系统重启时能够恢复已经安排的任务。此外,Quartz还拥有完善的事件体系,允许你注册各种事件的监听器。
本文详细介绍了Quartz任务调度的功能及配置方法,包括周期性和日历相关任务的设定,线程池配置,以及如何实现任务调度信息的持久化。
953

被折叠的 条评论
为什么被折叠?



