SpringBoot - 集成Quartz框架之常见问题(五)

写在前面

SpringBoot - 集成Quartz框架之CRON表达式
SpringBoot - 集成Quartz框架之Quartz简介(一)
SpringBoot - 集成Quartz框架之常用配置(二)
SpringBoot - 集成Quartz框架之具体步骤(三)
SpringBoot - 集成Quartz框架之独立数据源(四)
SpringBoot - 集成Quartz框架之常见问题(五)
SpringBoot - 集成Quartz框架之@DisallowConcurrentExecution注解详解(六)

1. 什么是失火策略?

场景描述

quartz-scheduler-misfire
失火策略也可以叫错误触发策略,由于JOB到了触发时间时没有被触发执行,而且被执行的延迟时间也超过了Quartz配置的misfireThreshold阈值,此时就会触发失火策略。有哪些原因没有被触发执行呢?
(1)JOB达到触发时间点时,所有线程都被其他JOB占用,没有可用线程;
(2)JOB达到触发时间点时,调度器停止了;
(3)JOB使用了@DisallowConcurrentExecution注解,使得JOB不能并发执行,当达到下一个JOB达到触发时间点时,上一个还未执行完毕;
(4)JOB设置的开始时间为已经过去的时间。

配置说明

针对CronTrigger触发器,定义了三种失火策略,如下:

.withMisfireHandlingInstructionIgnoreMisfires()
MISFIRE_INSTRUCTION_IGNORE_MISFIRE_POLICY = -1
所有未触发的执行都会立即执行,然后触发器再按计划运行。

.withMisfireHandlingInstructionFireAndProceed()
MISFIRE_INSTRUCTION_FIRE_ONCE_NOW = 1
立即执行第一个错误的执行并丢弃其他(即所有错误的执行合并在一起),也就是说无论错过了多少次触发器的执行,都只会立即执行一次,然后触发器再按计划运行。

.withMisfireHandlingInstructionDoNothing()
MISFIRE_INSTRUCTION_DO_NOTHING = 2
所有未触发的执行都将被丢弃,然后再触发器的下一个调度周期按计划运行。

2. 什么是JobStore?

JobStore用于跟踪提供给调度器的所有的数据,如:JOBS,TRIGGERS,日历等等。分为RAMJobStore和JDBCJobStore。
(1)RAMJobStore,是使用最简单的JobStore,也是性能最高的(在CPU时间方面)。缺点是当应用程序结束/崩溃时,所有调度信息都将丢失,这意味着RAMJobStore无法履行JOBS和TRIGGERS上的“非易失性”设置。
(2)JDBCJobStore,通过JDBC将其所有数据保存在数据库中。已被广泛应用于Oracle,PostgreSQL,MySQL,MS SQLServer,HSQLDB和DB2。要使用JDBCJobStore,首先要创建一组数据库表以供Quartz使用。可以在Quartz发行版的“docs/dbTables”目录中找到SQL脚本。

3. 触发器的状态有哪些?

状态 描述
WAITING 创建任务后,触发器的默认状态
ACQUIRED 当到达触发时间时的状态
EXECUTING 运行中
COMPLETE 完成(任务结束)
BLOCKED 阻塞状态
ERROR 错误状态
PAUSED 暂停状态
PAUSED_BLOCKED 暂停且阻塞状态(非并发下)
DELETED 删除状态

4. 如何获取SQL脚本?

官网:http://www.quartz-scheduler.org/
下载:quartz-2.4.0-SNAPSHOT-distribution.tar.gz
切换:quartz-2.4.0-SNAPSHOT-distribution/quartz-2.4.0-SNAPSHOT/src/org/quartz/impl/jdbcjobstore/路径下查找对应的数据库脚本。
SpringBoot - 集成Quartz框架之常见问题(五)_第1张图片
SpringBoot - 集成Quartz框架之常见问题(五)_第2张图片
SpringBoot - 集成Quartz框架之常见问题(五)_第3张图片

5. @QuartzDataSource注解的作用?

To have Quartz use a DataSource other than the application’s main DataSource, declare a DataSource bean, annotating its @Bean method with @QuartzDataSource. Doing so ensures that the Quartz-specific DataSource is used by both the SchedulerFactoryBean and for schema initialization.
如果Quartz框架使用除了应用程序主数据源之外的其他数据源,需要声明一个数据源BEAN,并使用@QuartzDataSource注解标注它的@Bean方法,这样才可以确保SchedulerFactoryBean创建以及初始化时,都使用特定于QUARTZ制定的数据源。
@QuartzDataSource注解是SpringBoot提供的与QUARTZ集成时使用指定数据的方案

6. 如何禁止并发执行相同定义的JOBDETAIL?

(1). 场景描述

Quartz定时任务默认是并发执行的,不会等待上一次任务执行完毕再执行下一个任务,当到达间隔时间就会执行对应的任务,如果定时任执行太长,会长时间占用资源导致其它任务堵塞,同时会出现多个线程并存的情况。如何解决呢? 可以在JOB的实现类上添加@DisallowConcurrentExecution注解,禁止并发执行。

(2). @DisallowConcurrentExecution注解的含义是什么?

@DisallowConcurrentExecution注解,用于禁止并发执行多个相同定义的JobDetail。该注解添加在JOB的实现类上的,不是不能同时执行多个JOB,而是不能并发执行同一个Job Definition(由JobDetail定义),允许同时执行多个不同的JobDetail。如:
一个任务设定的时间间隔为3秒,但该任务的执行时间是5秒,当在JOB实现类上添加@DisallowConcurrentExecution注解以后,程序会等待上一个周期的任务执行完毕以后再去执行,如果不添加该注解,则会在3秒时再启用新的线程执行该任务。

源码、示例及DEMO

源码、示例及DEMO

你可能感兴趣的:(SpringBoot,spring,boot,quartz)