spring cloud系列-06.spring cloud(spring boot)持久化quartz,实现动态定时任务

一,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

#================================================
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值