一,quartz简介
Quartz是OpenSymphony开源组织在Job scheduling领域又一个开源项目,它可以与J2EE与J2SE应用程序相结合也可以单独使用。Quartz可以用来创建简单或为运行十个,百个,甚至是好几万个Jobs这样复杂的程序。Jobs可以做成标准的Java组件或 EJBs。Quartz的最新版本为Quartz 2.3.0。
详细参考百度百科:https://baike.baidu.com/item/quartz/3643055?fr=aladdin
二,定时器种类
quartz中有5种类型的Trigger:
1)SimpleTrigger
2)CornTrigger
3)DateIntervalTrigger
4)NthIncludedDayTrigger
5)Caleendar
最常用的为
SimpleTrigger:用来触发只执行一次的或者在给定时间触发并且重复多次且每次执行延迟一定时间的任务。
CronTrigger:按照日历触发,比如每个周五,每天10点等等。
三,quartz两种调度信息存储方式
在业务场景中,不仅有定时执行的一些任务,比如每天几点执行一次,几小时几分几秒执行一次的定时任务,也有需要动态增加删除调整执行频率的定时任务。
quartz提供的执行任务的存储方式分为以下两种:
1)RAMJobStore:内存存储,不需要外部存储,运行速度快,配置简单。因为调度信息是存储在被分配给jvm的内存里面,所以当应用程序终止时,所有的调度信息都会丢失。另外也因为是存储在jvm的内存中,所以可以存储多少个Job和Trigger将会受到限制。
2)JDBCJobStore:数据库存储方式,持久化到数据库中。支持集群,因为所有的任务信息都会保存到数据库中,可以控制事务,如果服务器关闭或者重启,任务信息都不会丢失。并且可以恢复因服务器关闭或者重启而导致执行失败的任务。但这种方式的配置较复杂,速度受限于连接数据库的速度。
下面我们介绍下如何将任务信息持久化到数据库中,即JDBCJobStore存储方式的定时任务的实现例子。
四,JDBCJobStore存储方式定时任务例子
1)引入相关依赖
本人的工程使用的是Brixton.SR5 spring-cloud版本,spring-boot还应该引入spring-context-support包
<dependency>
<groupId>org.quartz-scheduler</groupId>
<artifactId>quartz</artifactId>
<version>2.3.0</version>
</dependency>
2)配置quartz.properties配置文件
# Default Properties file for use by StdSchedulerFactory
# to create a Quartz Scheduler Instance, if a different
# properties file is not explicitly specified.
#
#默认或是自己改名字都行
org.quartz.scheduler.instanceName: DefaultQuartzScheduler
#如果使用集群,instanceId必须唯一,设置成AUTO
org.quartz.scheduler.instanceId = AUTO
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.misfireThreshold: 60000
#============================================================================
# Configure JobStore
#============================================================================
#
#org.quartz.jobStore.class: org.quartz.simpl.RAMJobStore
#存储方式使用JobStoreTX,也就是数据库
org.quartz.jobStore.class:org.quartz.impl.jdbcjobstore.JobStoreTX
org.quartz.jobStore.driverDelegateClass:org.quartz.impl.jdbcjobstore.StdJDBCDelegate
#使用自己的配置文件
org.quartz.jobStore.useProperties:true
#数据库中quartz表的表名前缀
org.quartz.jobStore.tablePrefix:QRTZ_
org.quartz.jobStore.dataSource:quartzDs
#是否使用集群(如果项目只部署到 一台服务器,就不用了)
org.quartz.jobStore.isClustered = true
#================================================