SpringBoot日程管理Quartz与定时任务Task实现详解

目录
  • 1 Quartz
    • 核⼼概念
    • Springboot整合Quartz
      • 1.导⼊springboot整合Quartz的starter
      • 2.定义任务Bean
      • 3.创建Quartz配置类
  • 2. Task
    • 1.开启定时任务功能
    • 2.定义Bean
    • 3.配置文件

任务系统指的是定时任务。定时任务是企业级开发中必不可少的组成部分,诸如⻓周期业务数据的计算,都会⽤到定时任务

1 Quartz

Quartz是OpenSymphony开源组织在Job scheduling领域的⼀个开源项⽬,完全由Java开发的⼀个开源的任务⽇程管理系统,在预先确定(被纳⼊⽇程)的时间到达时,负责执⾏(或者通知)其他软件组件的系统。

核⼼概念

Job(任务):为⼀个接⼝,只定义⼀个⽅法 execute(JobExecutionContext context),在实现接⼝的execute⽅法中编写所需要定时执⾏的 Job(任务),JobExecutionContext类提供了调度应⽤的⼀些信息。Job运⾏时的信息保存在JobDataMap实例中。

JobDetail(任务信息):Quartz每次调度Job时,都重新创建⼀个Job实例,它不直接接受⼀个Job的实例,相反它接收⼀个Job实现类(JobDetail,描述Job的实现类及其他相关的静态信息,如Job名字、描述、关联监听器等信息)。

Trigger(触发器):为⼀个类,描述触发Job执⾏的时间触发规则。主要有SimpleTrigger和CronTrigger两个⼦类。当且仅当需调度⼀次或者以固定时间间隔周期执⾏调度,SimpleTrigger是最适合的选择;⽽CronTrigger则可以通过Cron表达式定义出各种复杂时间规则的调度⽅案。

Scheduler(调度器):调度器就相当于⼀个容器,装载着任务和触发器。该类是⼀个接⼝,代表⼀个Quartz的独⽴运⾏容器,Trigger和JobDetail可以注册到Scheduler中。

Springboot整合Quartz

1.导⼊springboot整合Quartz的starter

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

2.定义任务Bean

按照Quartz的开发规范制作,继承QuartzJobBean

public class MyQuartz extends QuartzJobBean {
    @Override
    protected void executeInternal(JobExecutionContext context) throws JobExecutionException {
        System.out.println("quartz task is going......");
    }
}

3.创建Quartz配置类

定义⼯作明细(JobDetail)与触发器的(Trigger)bean

@Configuration
public class QuartzConfig {
    @Bean
    public JobDetail testDetail(){
        return JobBuilder.newJob(MyQuartz.class).storeDurably().build();
    }
    @Bean
    public Trigger testJobTrigger(){
        //创建调度器
        ScheduleBuilder scheduleBuilder = CronScheduleBuilder.cronSchedule("0/5 * * * * ? ");
        //绑定对应的⼯作明细
        return TriggerBuilder.newTrigger().forJob(testDetail()).withSchedule(scheduleBuilder).build();
    }
}

cron表达式,定时执⾏

  • 第⼀位,表示秒,取值 0-59;
  • 第⼆位,表示分,取值 0-59;
  • 第三位,表示⼩时,取值 0-23;
  • 第四位,⽇期天/⽇,取值 1-31;
  • 第五位,⽇期⽉份,取值 1-12;
  • 第六位,星期,取值 1-7,星期⼀、星期⼆…;

注:不是第1周、第2周的意思,另外:1表示星期天,2表示星期⼀。

  • 第七位,年份,可以留空,取值 1970-2099。

特殊符号

  • (*)星号:可以理解为每的意思,每秒、每分、每天、每⽉、每年
  • (?)问号:问号只能出现在⽇期和星期这两个位置,表示这个位置的值不确定,每天 3点执⾏,所以第六位星期的位置是不需要关注的,就是不确定的值。同时,⽇期和星期是两个相互排斥的元素,通过问号来表明不指定值。假如 1 ⽉ 10 ⽇是星期⼀,如果在星期的位置是另指定星期⼆,就前后冲突⽭盾了
  • (-)减号:表达⼀个范围,如在⼩时字段中使⽤“10-12”,则表示从 10~12 点,即10、11、12
  • (,)逗号:表达⼀个列表值,如在星期字段中使⽤“1、2、4”,则表示星期⼀、星期⼆、星期四
  • (/)斜杠:如 x/y,x 是开始值,y 是步⻓,假设在第⼀位(秒) 0/15 就是,从 0秒开始,每 15 秒,最后就是 0、15、30、45、60,另 */y,等同于 0/y

总结

1. springboot整合Quartz就是将Quartz对应的核⼼对象交给spring容器管理,包含两个对象,JobDetail和Trigger对象

2. JobDetail对象描述的是⼯作的执⾏信息,需要绑定⼀个QuartzJobBean类型的对象

3. Trigger对象定义了⼀个触发器,需要为其指定绑定的JobDetail是哪个,同时要设置执⾏周期调度器

2. Task

spring根据定时任务的特征,将定时任务的开发简化到了极致。

1.开启定时任务功能

在引导类上开启定时任务功能的开关,使⽤注解@EnableScheduling

@SpringBootApplication
@EnableScheduling//打开定时任务开关
public class Demo12SpringbootTaskApplication {
    public static void main(String[] args) {
        SpringApplication.run(Demo12SpringbootTaskApplication.class, args);
    }
}

2.定义Bean

在对应要定时执⾏的操作上⽅,使⽤注解@Scheduled定义执⾏的时间,执⾏时间的描述⽅式还是cron表达式

@Component
public class MyBean {
    @Scheduled(cron = "0/1 * * * * ?")
    public void print() {
        System.out.println(Thread.currentThread().getName() + ":spring task run...");
    }
}

3.配置文件

如何想对定时任务进⾏相关配置,可以通过配置⽂件进⾏

spring:
  task:
    scheduling:
      ## 调度线程名称前缀 默认scheduling-
      thread-name-prefix: myTask_
      pool:
        # 任务调度线程池⼤⼩ 默认 1
        size: 1
      shutdown:
        # 线程池关闭时等待所有任务完成
        await-termination: false
        # 调度线程关闭前最⼤等待时间,确保最后⼀定关闭
        await-termination-period: 10s

总结

1. spring task需要使⽤注解@EnableScheduling开启定时任务功能

2. 为定时执⾏的的任务设置执⾏周期,描述⽅式cron表达式

到此这篇关于SpringBoot日程管理Quartz与定时任务Task实现详解的文章就介绍到这了,更多相关SpringBoot Quartz与Task内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • SpringBoot定时任务实现数据同步的方法

    本文实例为大家分享了SpringBoot定时任务实现数据同步的具体代码,供大家参考,具体内容如下 前言 业务的需求是,通过中台调用api接口获得,设备数据,要求现实设备数据的同步. 方案一:通过轮询接口的方式执行 pullData() 方法实现数据同步 该方式的原理是先清空之前的所有数据,然后重新插入通过api调用获取的最新数据.该方法的优点,逻辑简单.缺点是,频繁删除.插入数据.再调用查询数据时候,某一时刻,数据全部删除,还没及时插入的时候.数据可能有异常. 方案二:通过轮询接口的方式执行 p

  • 详解SpringBoot定时任务功能

    目录 一 背景 二 动态定时任务调度 三 多节点任务执行问题 四 后记 一 背景 项目中需要一个可以动态新增定时定时任务的功能,现在项目中使用的是xxl-job定时任务调度系统,但是经过一番对xxl-job功能的了解,发现xxl-job对项目动态新增定时任务,动态删除定时任务的支持并不是那么好,所以需要自己手动实现一个定时任务的功能 二 动态定时任务调度 1 技术选择 Timer or ScheduledExecutorService 这两个都能实现定时任务调度,先看下Timer的定时任务调度

  • SpringBoot集成quartz实现定时任务详解

    目录 准备知识点 什么是Quartz Quartz的体系结构 什么是Quartz持久化 实现案例 - 单实例方式 实现案例 - 分布式方式 后端实现 前端实现 测试效果 准备知识点 需要了解常用的Quartz框架. 什么是Quartz 来源百度百科, 官网地址:http://www.quartz-scheduler.org/ Quartz是OpenSymphony开源组织在Job scheduling领域又一个开源项目,它可以与J2EE与J2SE应用程序相结合也可以单独使用.Quartz可以用来

  • SpringBoot+Quartz实现动态定时任务

    本文实例为大家分享了springBoot+Quartz实现动态定时任务的具体代码,供大家参考,具体内容如下 目前常用的几种任务调度 Timer,简单无门槛,一般也没人用. spring @Scheduled注解,一般集成于项目中,小任务很方便. 开源工具 Quartz,分布式集群开源工具,以下两个分布式任务应该都是基于Quartz实现的,可以说是中小型公司必选,当然也视自身需求而定. 分布式任务 XXL-JOB,是一个轻量级分布式任务调度框架,支持通过 Web 页面对任务进行 CRUD 操作,支

  • SpringBoot 整合 Quartz 定时任务框架详解

    目录 前言 一.简单聊一聊 Quartz 1.1.Quartz 概念 二.SpringBoot 使用 Quartz 2.1.基本步骤 2.2.执行 Quartz 需要的SQL文件 2.3.Controller 2.4.Service 划重点 2.5.实体类 2.6.简单的 Job 案例 2.7.那么该如何使用呢? 前言 在选择技术栈之前,一定要先明确一件事情,你真的需要用它吗?还有其他方式可以使用吗? 相比其他技术技术,优点在哪里呢?使用了之后的利与弊等等. 写这个主要是因为一直想写一下定时任务

  • Springboot实现动态定时任务流程详解

    目录 一.静态 二.动态 1.基本代码 2.方案详解 2.1 初始化 2.2 单次执行 2.3 停止任务 2.4 启用任务 三.小结 一.静态 静态的定时任务可以直接使用注解@Scheduled,并在启动类上配置@EnableScheduling即可 @PostMapping("/list/test1") @Async @Scheduled(cron = "0 * * * * ?") public void test1() throws Exception { Ob

  • SpringBoot整合Quartz实现定时任务详解

    目录 Quartz简介 核心概念 Scheduler JobDetail Job Trigger SpringBoot整合Quartz 准备数据库表 Maven相关依赖 配置文件 quartz配置类 创建任务类 创建监听类 运行结果 Quartz简介 Quartz 是一个开源的作业调度框架,它完全由 Java 写成,并设计用于 J2SE 和 J2EE 应用中.它提供了巨大的灵活性而不牺牲简单性.你能够用它来为执行一个作业而创建简单的或复杂的调度.它有很多特征,如:数据库支持,集群,插件,EJB

  • SpringBoot日程管理Quartz与定时任务Task实现详解

    目录 1 Quartz 核⼼概念 Springboot整合Quartz 1.导⼊springboot整合Quartz的starter 2.定义任务Bean 3.创建Quartz配置类 2. Task 1.开启定时任务功能 2.定义Bean 3.配置文件 任务系统指的是定时任务.定时任务是企业级开发中必不可少的组成部分,诸如⻓周期业务数据的计算,都会⽤到定时任务 1 Quartz Quartz是OpenSymphony开源组织在Job scheduling领域的⼀个开源项⽬,完全由Java开发的⼀

  • springBoot项目集成quartz开发定时任务案例及注意事项

    目录 quartz下载.安装 实战案例 常见问题及解决方案 quartz下载.安装 Quartz是完全由java开发的一个开源的任务日程管理系统,任务进度管理器就是一个在预先确定的时间到达时,负责执行(或者通知)一段程序或功能的系统,即定时执行某个任务.Quartz用一个小Java库发布文件(.jar文件),这个库文件包含了所有Quartz核心功能.这些功能的主要接口(API)是Scheduler接口.它提供了简单的操作,例如:将任务纳入日程或者从日程中取消,开始/停止/暂停日程进度. 上图是q

  • SpringBoot设置动态定时任务的方法详解

    之前写过文章记录怎么在SpringBoot项目中简单使用定时任务,不过由于要借助cron表达式且都提前定义好放在配置文件里,不能在项目运行中动态修改任务执行时间,实在不太灵活. 经过网上搜索学习后,特此记录如何在SpringBoot项目中实现动态定时任务. 因为只是一个demo,所以只引入了需要的依赖: <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <ar

  • Spring Task定时任务的实现详解

    目录 Spring Task定时任务 Cron表达式 实现定时任务 背景 实现 Spring Task定时任务 Cron表达式 以6-7位的一组数字,中间用空格间隔的字符串,表达一种时间 每位的含义及取值范围: 秒(0-59) 分(0-59) 时(0-23) 日(1-31) 月(1-12) 周(1-7或SUN-SAT) 年(四位数,可省略) 符号的含义: *表示所有值(秒位是*,则表示每秒) ?表示未说明的值,(日和周必须有一位为?,因为不合逻辑) -表示一个指定的范围 ,表示一个可能值 /符号

  • Java实现定时任务的方法详解

    目录 前言 定时任务是什么 定时任务的有哪些是实现方式 纯手写单线程循环 Timer 和它的小伙伴 ScheduledExecutorService Spring 提供的定时任务 总结 前言 学过定时任务,但是我忘了,忘得一干二净,害怕,一直听别人说: 你写一个定时任务就好了. 写个定时任务让他去爬取就行了. 我不会,所以现在得补回来了,欠下的终究要还的,/(ㄒoㄒ)/~~ 定时任务是什么 大家都用过闹钟,闹钟可以说是一种定时任务. 比如我们设定了周一到周五早上7点半的时间响铃,那么闹钟就会在周

  • Springboot Vue可配置调度任务实现示例详解

    目录 正文 1.表结构: 2.接口: 3.业务层: 4.Mapper 5.前端(Vue): 正文 Springboot + Vue,定时任务调度的全套实现方案. 这里用了quartz这个框架,实现分布式调度任务很不错,关于quarz的使用方式改天补一篇.相当简单. 1.表结构: sys_job 列名 数据类型 长度 是否可空 是否主键 说明 job_id bigint 否 是 任务ID job_name varchar 64 否 是 任务名称 job_group varchar 64 否 是 任

  • Spring quartz Job依赖注入使用详解

    Spring quartz Job依赖注入使用详解 一.问题描述: 使用Spring整合quartz实现动态任务时,想在job定时任务中使用某个service时,直接通过加注解@Component.@Autowired是不能注入的,获取的对象为Null.如下面的代码: @Component @PersistJobDataAfterExecution @DisallowConcurrentExecution public class TicketSalePriceLessThanLowestPri

  • Spring Boot启动过程(五)之Springboot内嵌Tomcat对象的start教程详解

    标题和Spring Boot启动过程(四)之Spring Boot内嵌Tomcat启动很像,所以特别强调一下,这个是Tomcat对象的. 从TomcatEmbeddedServletContainer的this.tomcat.start()开始,主要是利用LifecycleBase对这一套容器(engine,host,context及wrapper)进行启动并发布诸如configure_start.before_init.after_start的lifecycleEvent事件给相应的监听器(如

  • springboot jpa分库分表项目实现过程详解

    这篇文章主要介绍了springboot jpa分库分表项目实现过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 分库分表场景 关系型数据库本身比较容易成为系统瓶颈,单机存储容量.连接数.处理能力都有限.当单表的数据量达到1000W或100G以后,由于查询维度较多,即使添加从库.优化索引,做很多操作时性能仍下降严重.此时就要考虑对其进行切分了,切分的目的就在于减少数据库的负担,缩短查询时间. 分库分表用于应对当前互联网常见的两个场景--大数

  • navicat创建MySql定时任务的方法详解

    navicat创建MySql 定时任务详解 事件(event)是MySQL在相应的时刻调用的过程式数据库对象.一个事件可调用一次,也可周期性的启动,它由一个特定的线程来管理的,也就是所谓的"事件调度器".事件和触发器类似,都是在某些事情发生的时候启动.当数据库上启动一条语句的时候,触发器就启动了,而事件是根据调度事件来启动的.由于他们彼此相似,所以事件也称为临时性触发器.事件取代了原先只能由操作系统的计划任务来执行的工作,而且MySQL的事件调度器可以精确到每秒钟执行一个任务,而操作系

随机推荐