前言:由于我们本项目选用的Springboot来整合Quartz,官方给我们提供了启动器所以很简单。在以前的版本我们想要使用Quartz需要引入的依赖如下:

<dependency>
<groupId>org.quartz-scheduler</groupId>
<artifactId>quartz</artifactId>
<version>2.2.3</version>
</dependency>
<dependency>
<groupId>org.quartz-scheduler</groupId>
<artifactId>quartz-jobs</artifactId>
<version>2.2.3</version>
</dependency>

按以上的方式来使用Quartz的话,或需要我们创建很多的配置类:Job的工厂类等。

但是现在我们有了官方的启动器,依赖如下:

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-quartz</artifactId>
</dependency>

此时我们不需要配置很多配置类,只需要在我们的application.yaml文件中配置必要的信息就ok了。

创建springboot项目,并加入所需依赖

加入数据库依赖

<!--mysql驱动依赖-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.1.16</version>
</dependency>
<!--mybatis-plus 快速开发-->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.2.0</version>
</dependency>

配置基本配置

spring:
quartz:
auto-startup: true
properties:
org:
quartz:
scheduler:
instanceName: clusteredScheduler
instanceId: AUTO
jobStore:
class: org.quartz.impl.jdbcjobstore.JobStoreCMT
driverDelegateClass: org.quartz.impl.jdbcjobstore.StdJDBCDelegate
tablePrefix: QRTZ_
isClustered: true
clusterCheckinInterval: 10000
useProperties: false
threadPool:
class: org.quartz.simpl.SimpleThreadPool
threadCount: 20
threadPriority: 5
threadsInheritContextClassLoaderOfInitializingThread: true
job-store-type: jdbc
wait-for-jobs-to-complete-on-shutdown: true
datasource:
type: com.alibaba.druid.pool.DruidDataSource
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://localhost:3306/quartz?useUnicode=true&useSSL=false&characterEncoding=utf8&serverTimezone=UTC&allowPublicKeyRetrieval=true
username: root
password: root
initialSize: 20
minIdle: 5
timeBetweenEvictionRunsMillis: 60000
minEvictableIdleTimeMillis: 30000
testWhileIdle: true
filters: stat,wall,sl4j
connectionProperties: druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000

quartz涉及表说明

涉及表说明

qrtz_calendars :存储quartz的calendar日历信息.
qrtz_cron_triggers :存储cron trigger,包括cron表达式和时区信息。
qrtz_fired_triggers :存储与已触发的trigger相关的状态信息,以及相联job的执行信息
qrtz_job_details :存储每一个已配置的job的详细信息
qrtz_locks :存储程序的非观锁的信息(假如使用了悲观锁)
qrtz_paused_trigger_grps :存储已暂停的trigger组的信息
qrtz_scheduler_state :存储少量的有关 scheduler的状态信息,和别的 scheduler 实例
qrtz_simple_triggers :存储简单的 trigger,包括重复次数,间隔,以及已触的次数
qrtz_simprop_triggers
qrtz_triggers :存储已配置的 trigger的信息

表属性说明

qrtz_calendars表

字段中文名 字段英文名 数据类型
计划名称 SCHED_NAME VARCHAR2(120)
触发器名称 CALENDAR_NAME VARCHAR2(200)
日历 CALENDA BLO

qrtz_cron_triggers表

字段中文名 字段英文名 数据类型
计划名称 SCHED_NAME VARCHAR2(120)
定时任务类名 TRIGGER_NAME VARCHAR2(200)
任务分类 TRIGGER_GROUP VARCHAR2(200)
cron表达式 CRON_EXPRESSION VARCHAR2(120)
时间区域 TIME_ZONE_I VARCHAR2(80 )

qrtz_fired_triggers表

字段中文名 字段英文名 数据类型
计划名称 SCHED_NAME VARCHAR2(120)
组标识 ENTRY_ID VARCHAR2(95)
触发器名称 TRIGGER_NAME VARCHAR2(200)
触发器组 TRIGGER_GROUP VARCHAR2(200)
当前实例的名称 INSTANCE_NAME VARCHAR2(200)
当前执行时间 FIRED_TIME NUMBER(13)
计划时间 SCHED_TIME NUMBER(13)
权重 PRIORITY NUMBER
状态 STATE VARCHAR2(16)
作业名称 JOB_NAME VARCHAR2(200)
作业组 JOB_GROUP VARCHAR2(200)
是否并行 IS_NONCONCURRENT VARCHAR2(1)
是否要求唤醒 REQUESTS_RECOVERY VARCHAR2(1)

qrtz_job_details表

字段中文名 字段英文名 数据类型
调度名称 SCHED_NAME VARCHAR2(120)
job的名字 JOB_NAME VARCHAR2(200)
job的所属组的名 JOB_GROUP VARCHAR2(200)
相关介绍 DESCRIPTION VARCHAR2(250)
job实现类的完全 JOB_CLASS_NAME VARCHAR2(250)
是否持久化 IS_DURABLE VARCHAR2(1)
是否并发 IS_NONCONCURRENT VARCHAR2(1)
是否更新数据 IS_UPDATE_DATA VARCHAR2(1)
是否接受恢复执行 REQUESTS_RECOVERY VARCHAR2(1)
存放持久job对象 JOB_DATA BLOB

qrtz_locks表

字段中文名 字段英文名 数据类型
计划名称 SCHED_NAME VARCHAR2(120)
锁名 LOCK_NAM VARCHAR2(40)

qrtz_paused_trigger_grps表

字段中文名 字段英文名 数据类型
计划名称 SCHED_NAME VARCHAR2(120)
触发器组 TRIGGER_GROUP VARCHAR2(200)

qrtz_scheduler_state表

字段中文名 字段英文名 数据类型
计划名称 SCHED_NAME VARCHAR2(120)
实例名称 INSTANCE_NAME VARCHAR2(200)
最后的检查时间 LAST_CHECKIN_TIME NUMBER(13)
检查间隔 CHECKIN_INTERVAL NUMBER(13)

qrtz_simple_triggers表

字段中文名 字段英文名 数据类型
计划名称 SCHED_NAME VARCHAR2(120)
触发器名称 TRIGGER_NAME VARCHAR2(200)
触发器组 TRIGGER_GROUP VARCHAR2(200)
重复次数 REPEAT_COUNT NUMBER(7)
触发次数 REPEAT_INTERVAL NUMBER(12)
重复间隔 TIMES_TRIGGERED NUMBER(10)

qrtz_triggers表

字段中文名 字段英文名 数据类型
计划名称 SCHED_NAME VARCHAR2(120)
触发器名称 TRIGGER_NAME VARCHAR2(200)
触发器组 TRIGGER_GROUP VARCHAR2(200)
作业名称 JOB_NAME VARCHAR2(200)
作业组 JOB_GROUP VARCHAR2(200)
描述 DESCRIPTION VARCHAR2(250)
下次执行时间 NEXT_FIRE_TIME NUMBER(13)
前一次执行时间 PREV_FIRE_TIME NUMBER(13)
优先权 PRIORITY NUMBER
触发器状态 TRIGGER_STATE VARCHAR2(16)
触发器类型 TRIGGER_TYPE VARCHAR2(8)
开始时间 START_TIME NUMBER(13)
结束时间 END_TIME NUMBER(13)
日历名称 CALENDAR_NAME VARCHAR2(200)
失败次数 MISFIRE_INSTR NUMBER
作业数据 JOB_DATA BLOB

SpringBoot之Quartz基础的更多相关文章

  1. SpringBoot之Quartz实战

    说明:由于上篇文章我们已经讨论过springboot整合Quartz及相关配置,本次我们只说明Qrtz的增.删.改.启动.停止相关api的使用,其中涉及的其他技术,如:mybatisplus等技术以后 ...

  2. Springboot集成Quartz

    之前学习过spring的定时任务 :https://www.cnblogs.com/slimshady/p/10112515.html 本文主要学习记录下springboot使用quartz 1.   ...

  3. Spring-Boot之Redis基础

    Spring-Boot之Redis基础 准备 Redis下载地址:github.com/MSOpenTech/redis/releases Redis数据库的默认端口号是 6379 开启Redis服务 ...

  4. SpringBoot整合Quartz定时任务 系统job Spring Boot教程 调度任务

    原文地址:https://www.cnblogs.com/allalongx/p/8477368.html 构建工程 创建一个Springboot工程,在它的程序入口加上@EnableScheduli ...

  5. springboot和quartz整合实现动态定时任务(持久化单节点)

    Quartz是一个完全由java编写的开源作业调度框架,为在Java应用程序中进行作业调度提供了简单却强大的机制,它支持定时任务持久化到数据库,从而避免了重启服务器时任务丢失,支持分布式多节点,大大的 ...

  6. SpringBoot整合Quartz作为调度中心完整实用例子

    因为想要做一个类似于调度中心的东西,定时执行一些Job(通常是一些自定义程序或者可执行的jar包),搭了一个例子,总结了前辈们的相关经验和自己的一些理解,如有雷同或不当之处,望各位大佬见谅和帮忙指正. ...

  7. SpringBoot整合Quartz定时任务

    记录一个SpringBoot 整合 Quartz 的Demo实例 POM.XML文件 <!-- 定时器任务 quartz需要导入的坐标 --> <dependency> < ...

  8. Quartz基础调度框架-第二篇服务

    很多应用场景Quartz运行于Windows服务 Conf 在这个基本结构里 是用来存放配置  和上一篇 控制台运行的一样的结构 jobs.xml 的配置清单 <!-- 任务配置--> & ...

  9. Quartz基础调度框架-第一篇控制台

    Quartz基础调度框架 Quartz核心的概念:scheduler任务调度.Job任务.Trigger触发器.JobDetail任务细节 结构 Conf 在这个基本结构里 是用来存放配置 publi ...

随机推荐

  1. 关于C++命名空间namespace的理解与使用介绍

    0X00 前言 所谓namespace,是指标识符的各种可见范围.C++标准程序库中的所有标识符都被定义于一个名为std的namespace中. 0x01 与C语言区别 <iostream> ...

  2. 一小时完成后台开发:DjangoRestFramework开发实践

    DjangoRestFramework开发实践 在这之前我写过一篇关于Django与Drf快速开发实践的博客,Django快速开发实践:Drf框架和xadmin配置指北,粗略说了一下Drf配置和基本使 ...

  3. 【Nginx】实现负载均衡、限流、缓存、黑白名单和灰度发布,这是最全的一篇了!

    写在前面 在<[高并发]面试官问我如何使用Nginx实现限流,我如此回答轻松拿到了Offer!>一文中,我们主要介绍了如何使用Nginx进行限流,以避免系统被大流量压垮.除此之外,Ngin ...

  4. flask 源码专题(八):路由加载

    1.示例代码 from flask import Flask app = Flask(__name__,static_url_path='/xx') @app.route('/index') def ...

  5. Drf06 /drf总结

    Drf06 /drf总结 目录 Drf06 /drf总结 1. restful规范 2. drf组件认证的实现过程? 3. drf组件中权限的实现过程? 4. drf组件中节流的实现方式? 5. 什么 ...

  6. SQLite数据库多平台应用及常见错误分析

    SQLite是一个软件库,实现了自给自足的.无服务器的.零配置的.事务性的SQL数据库引擎.SQLite是世界上最广泛部署的数据库引擎之一.SQLite源代码开放,没有授权限制.正是因为其免费.轻巧. ...

  7. 转:Oracle 数据泵详解

    一.EXPDP和IMPDP使用说明 Oracle Database 10g引入了最新的数据泵(Data Dump)技术,数据泵导出导入(EXPDP和IMPDP)的作用 1)实现逻辑备份和逻辑恢复. 2 ...

  8. vue : async / await 的应用

    比如有组数据是很多页面都要用的,我想把它写在一个js文件里作为公共方法. public.js import axios from 'axios'; axios.defaults.headers.pos ...

  9. C++语法小记---同名覆盖

    同名覆盖 子类中的同名成员会覆盖父类中的同名成员,但是在内存中仍然存在,只是无法直接访问,需要加上域名才能访问 子类中的同名函数会覆盖父类中的函数,复写是同名覆盖的一种特殊情况,只要不是多态场景,复写 ...

  10. web自动化 -- js操作(滑动屏幕、修改页面)

    一.selenium对  js  的操作方法 1.先定义  js 操作   或者  定义  目标元素 2.执行  js  操作:  driver.execute_script(js操作)    或者  ...