首页 > 其他分享 >SpringBoot整合quartz定时任务

SpringBoot整合quartz定时任务

时间:2024-10-30 17:11:36浏览次数:6  
标签:quartz SpringBoot public 任务 org import jobInfo 定时

Quartz基本概念

Quartz是一个任务调度框架,主要用于在特定时间触发任务执行。‌

Quartz的核心概念
‌调度器(Scheduler)‌:负责任务的调度和管理,包括任务的启动、暂停、恢复等操作。
‌任务(Job)‌:需要实现org.quartz.Job接口的execute方法,定义了任务的具体执行逻辑。
‌触发器(Trigger)‌:定义任务执行的触发条件,包括简单触发器(SimpleTrigger)和cron触发器(CronTrigger)。
‌任务详情(JobDetail)‌:用于定义任务的详细信息,如任务名、组名等。
‌任务构建器(JobBuilder)和触发器构建器(TriggerBuilder)‌:用于定义和构建任务和触发器的实例。
‌线程池(ThreadPool)‌:用于并行调度执行每个作业,提高效率。
‌监听器(Listener)‌:包括任务监听器、触发器监听器和调度器监听器,用于监听任务和触发器的状态变化。
Quartz的基本使用步骤
‌创建任务类‌:实现Job接口的execute方法,定义任务的执行逻辑。
‌生成任务详情(JobDetail)‌:通过JobBuilder定义任务的详细信息。
‌生成触发器(Trigger)‌:通过TriggerBuilder定义任务的触发条件,可以选择使用简单触发器或cron触发器。
‌获取调度器(Scheduler)‌:通过SchedulerFactory创建调度器对象,并将任务和触发器绑定在一起,启动调度器。
Quartz的优点和缺点
‌优点‌:支持复杂的调度需求,包括定时、重复执行、并发执行等;提供了丰富的API和工具类,易于使用和维护;支持Spring集成,方便在Spring项目中应用。
‌缺点‌:配置复杂,需要一定的学习成本;对于简单的定时任务,使用Quartz可能会显得过于复杂。

整合SpringBoot

第一步:添加依赖

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

第二步:创建scheduler

package com.xy.quartz;

import org.quartz.Scheduler;
import org.quartz.SchedulerException;
import org.quartz.SchedulerFactory;
import org.quartz.impl.StdSchedulerFactory;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class QuartzConfig {
    @Bean
    public Scheduler scheduler() throws SchedulerException {
        SchedulerFactory schedulerFactoryBean = new StdSchedulerFactory();
        return schedulerFactoryBean.getScheduler();
    }
}

第三步:创建Job

import com.songwp.utils.DateUtil;
import lombok.extern.slf4j.Slf4j;
import org.quartz.Job;
import org.quartz.JobDataMap;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;
import org.springframework.stereotype.Component;

import java.util.Date;

@Slf4j
@Component
public class MyJob implements Job {
    @Override
    public void execute(JobExecutionContext jobExecutionContext) throws JobExecutionException {
        JobDataMap jobDataMap = jobExecutionContext.getJobDetail().getJobDataMap();
        log.info("入参:{}", jobDataMap.toString());
        log.info("执行定时任务的时间:{}", DateUtil.dateToStr(new Date()));
    }
}

第四步:创建任务信息类

import lombok.Data;

@Data
public class JobInfo {
    private Long jobId;
    private String cronExpression;
    private String businessId;
}

第五步:创建JobDetail和trigger创建包装类

import com.songwp.domain.quartz.JobInfo;
import com.songwp.test.MyJob;
import org.quartz.*;
import java.util.Date;

public class QuartzBuilder {
    public static final String RUN_CRON ="定时执行";
    public static final String RUN_ONE ="执行一次";
    private static final String JOB_NAME_PREFIX ="flow";
    public static final String TRIGGER_NAME_PREFIX ="trigger.";

    public static JobDetail createJobDetail(JobInfo jobInfo, String type){
        String jobKey =JOB_NAME_PREFIX + jobInfo.getJobId();
        if (RUN_ONE.equals(type)){
            jobKey = JOB_NAME_PREFIX + new Date().getTime();
        }

        return JobBuilder.newJob(MyJob.class)
                .withIdentity(jobKey,"my_group")
                .usingJobData("businessId",jobInfo.getBusinessId())
                .usingJobData("businessType","其他参数")
                .storeDurably().build();
    }


    public static Trigger createTrigger(JobDetail jobDetail, JobInfo jobInfo){
        return TriggerBuilder.newTrigger()
                .forJob(jobDetail)
                .withIdentity(TRIGGER_NAME_PREFIX + jobInfo.getJobId(),RUN_CRON)
                .withSchedule(CronScheduleBuilder.cronSchedule(jobInfo.getCronExpression()))
                .build();
        }
}

第六步:控制层接口实现接口(执行一次、启动定时、暂停任务)

import com.songwp.config.quartz.QuartzBuilder;
import com.songwp.domain.quartz.JobInfo;
import lombok.extern.slf4j.Slf4j;
import org.quartz.*;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.annotation.PostConstruct;

@RestController
@Slf4j
public class QuartzController {

    @Autowired
    private Scheduler scheduler;

    /**
     * 定时任务执行(只执行一次)
     * @return
     */
    @GetMapping("runOne")
    public  String runOne(){
        JobInfo jobInfo = new JobInfo();
        jobInfo.setJobId(1L);
        jobInfo.setBusinessId("123");
        jobInfo.setCronExpression("0/5 * * * * ?");
        JobDetail jobDetail = QuartzBuilder.createJobDetail(jobInfo, QuartzBuilder.RUN_ONE);
        Trigger trigger = TriggerBuilder.newTrigger()
                .forJob(jobDetail)
                .startNow()
                .withSchedule(SimpleScheduleBuilder.simpleSchedule().withRepeatCount(0))
                .build();

        try {
            scheduler.scheduleJob(jobDetail, trigger);
            if (!scheduler.isStarted()) {
                scheduler.start();
            }
        } catch (SchedulerException e) {
            log.error(e.getMessage());
            return "执行失败";
        }
        return "执行成功";
    }

    /**
     * 开始定时执行
     * @return 执行结果
     */
    @GetMapping("start")
    public String start() {
        try {
            JobInfo jobInfo = new JobInfo();
            jobInfo.setJobId(1L);
            jobInfo.setBusinessId("123");
            jobInfo.setCronExpression("0/5 * * * * ?");
            TriggerKey triggerKey = new TriggerKey(QuartzBuilder.TRIGGER_NAME_PREFIX + jobInfo.getJobId(),QuartzBuilder.RUN_CRON);
            if (scheduler.checkExists(triggerKey)) {
                scheduler.resumeTrigger(triggerKey);
            } else {
                JobDetail jobDetail = QuartzBuilder.createJobDetail(jobInfo, QuartzBuilder.RUN_CRON);
                Trigger trigger = QuartzBuilder.createTrigger(jobDetail, jobInfo);
                scheduler.scheduleJob(jobDetail, trigger);
                if (!scheduler.isStarted()) {
                    scheduler.start();
                }
            }
        } catch (SchedulerException e) {
            log.error(e.getMessage());
            return "执行失败";

        }
        return "执行成功";
    }

    /**
     * 停止任务执行
     * @return 执行结果
     */
    @GetMapping("pause")
    public String pause() {
        try {
            JobInfo jobInfo = new JobInfo();
            jobInfo.setJobId(1L);
            jobInfo.setBusinessId("123");
            jobInfo.setCronExpression("0/5 * * * * ?");
            TriggerKey triggerKey = new TriggerKey(QuartzBuilder.TRIGGER_NAME_PREFIX + jobInfo.getJobId(), QuartzBuilder.RUN_CRON);
            if (scheduler.checkExists(triggerKey)) {
                scheduler.pauseTrigger(triggerKey);
            }
        } catch (SchedulerException e) {
            log.error(e.getMessage());
            return "执行失败";
        }
        return "执行成功";
    }

    /**
     * 查询已启动状态的任务,然后重新执行
     */
    @PostConstruct
    public void init(){
       log.info("查询已启动状态的任务,然后重新执行");
        start();
    }

}

最后访问接口:

http://localhost:8080/runOne
http://localhost:8080/start
http://localhost:8080/pause

正常情况下的步骤应该是这样:

1、创建任务时记录到任务表job_info,此时初始状态为0

2、启动任务时更新任务表状态,更新为1

3、如果应用关闭了,那么在下次应用启动的时候,需要把状态为1的任务也给启动了,就不需要认为再去调接口启动。

标签:quartz,SpringBoot,public,任务,org,import,jobInfo,定时
From: https://www.cnblogs.com/songweipeng/p/18516181

相关文章

  • SpringBoot安卓开发的水果商城app (案例分析)-附源码
    摘  要在移动互联网的快速发展背景下,手机应用已成为人们生活中不可或缺的一部分。水果商城App作为电商领域的重要应用之一,为用户提供便捷的购物体验和丰富的商品选择。本研究旨在基于Android平台开发水果商城App,结合SpringBoot框架和Mysql数据库,以实现功能强大、操作简......
  • 后台管理系统的通用权限解决方案(七)SpringBoot整合SpringEvent实现操作日志记录(基于
    1SpringEvent框架除了记录程序运行日志,在实际项目中一般还会记录操作日志,包括操作类型、操作时间、操作员、管理员IP、操作原因等等(一般叫审计)。操作日志一般保存在数据库,方便管理员查询。通常的做法在每个请求方法中构建审计对象,并写入数据库,但这比较繁琐和冗余。更简......
  • 【JavaEE】【多线程】定时器
    目录一、定时器简介1.1Timer类1.2使用案例二、实现简易定时器2.1MyTimerTask类2.2实现schedule方法2.3构造方法2.4总代码2.5测试一、定时器简介定时器:就相当于一个闹钟,当我们定的时间到了,那么就执行一些逻辑。1.1Timer类Java的标准库中提供了在java.ut......
  • djangoadmin定时检查产品是否过期
    Django本身并没有内置的定时任务系统,但你可以使用Django的管理命令结合系统的cron来实现定时检查。这是一个简单且有效的方法,特别适合中小型项目。以下是实现步骤:创建自定义管理命令在你的Django应用目录下创建一个management/commands目录结构,然后在其中创建一个......
  • 毕业生招聘新时代:SpringBoot平台
    摘要随着社会的发展,社会的各行各业都在利用信息化时代的优势。计算机的优势和普及使得各种信息系统的开发成为必需。毕业生信息招聘平台,主要的模块包括查看管理员;首页、个人中心、企业管理、空中宣讲会管理、招聘岗位管理、毕业生管理、个人简历管理、求职信息管理、信息......
  • SpringBoot框架:毕业生招聘市场的革新
    摘要随着社会的发展,社会的各行各业都在利用信息化时代的优势。计算机的优势和普及使得各种信息系统的开发成为必需。毕业生信息招聘平台,主要的模块包括查看管理员;首页、个人中心、企业管理、空中宣讲会管理、招聘岗位管理、毕业生管理、个人简历管理、求职信息管理、信息......
  • 几种防止SpringBoot 程序崩溃的方法
    引言在SpringBoot应用程序中,为了预防程序崩溃并确保应用的稳定运行,可以采取以下几种策略来达成目标:一、全局异常处理在SpringBoot应用程序中,为了有效管理异常并防止它们直接导致程序崩溃,可以利用Spring的@ControllerAdvice和@ExceptionHandler注解。通过这种方式,可以集中......
  • 基于Java+SpringBoot+Vue的课程答疑系统
    基于Java+SpringBoot+Vue的课程答疑系统前言✌全网粉丝20W+,csdn特邀作者、博客专家、CSDN[新星计划]导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌......
  • 基于Java+SpringBoot+Mysql实现的古诗词平台功能设计与实现九
    一、前言介绍:1.1项目摘要随着信息技术的迅猛发展和数字化时代的到来,传统文化与现代科技的融合已成为一种趋势。古诗词作为中华民族的文化瑰宝,具有深厚的历史底蕴和独特的艺术魅力。然而,在现代社会中,由于生活节奏的加快和信息获取方式的多样化,古诗词的传播和阅读面临着一......
  • 基于Java+SpringBoot+Mysql实现的古诗词平台功能设计与实现十
    一、前言介绍:1.1项目摘要随着信息技术的迅猛发展和数字化时代的到来,传统文化与现代科技的融合已成为一种趋势。古诗词作为中华民族的文化瑰宝,具有深厚的历史底蕴和独特的艺术魅力。然而,在现代社会中,由于生活节奏的加快和信息获取方式的多样化,古诗词的传播和阅读面临着一......