版权声明:本文为博主原创文章,转载请注明出处。 https://blog.csdn.net/liuchuanhong1/article/details/78543574

最近收到了很多封邮件,都是想知道spring boot整合quartz如何实现多个定时任务的,由于本人生产上并没有使用到多个定时任务,这里给个实现的思路。

1、新建两个定时任务,如下:

  1.  
    public class ScheduledJob implements Job{
  2.  
    @Override
  3.  
    public void execute(JobExecutionContext context) throws JobExecutionException {
  4.  
    System.out.println("schedule job1 is running…………………………………… ");
  5.  
    }
  6.  
    }

  1.  
    public class ScheduledJob2 implements Job {
  2.  
     
  3.  
    @Override
  4.  
    public void execute(JobExecutionContext context) throws JobExecutionException {
  5.  
    System.out.println("schedule job2 is running ……………………………………………………");
  6.  
    }
  7.  
    }

2、配置以上两个任务

  1.  
    @Component
  2.  
    public class SchedulerAllJob {
  3.  
    @Autowired
  4.  
    private SchedulerFactoryBean schedulerFactoryBean;
  5.  
     
  6.  
    /*
  7.  
    * 此处可以注入数据库操作,查询出所有的任务配置
  8.  
    */
  9.  
     
  10.  
    /**
  11.  
    * 该方法用来启动所有的定时任务
  12.  
    * @throws SchedulerException
  13.  
    */
  14.  
    public void scheduleJobs() throws SchedulerException {
  15.  
    Scheduler scheduler = schedulerFactoryBean.getScheduler();
  16.  
     
  17.  
    /**
  18.  
    *
  19.  
    */
  20.  
    scheduleJob1(scheduler);
  21.  
    scheduleJob2(scheduler);
  22.  
    }
  23.  
     
  24.  
    /**
  25.  
    * 配置Job1
  26.  
    * 此处的任务可以配置可以放到properties或者是放到数据库中
  27.  
    * 如果此时需要做到动态的定时任务,请参考:http://blog.csdn.net/liuchuanhong1/article/details/60873295
  28.  
    * 博客中的ScheduleRefreshDatabase类
  29.  
    * @param scheduler
  30.  
    * @throws SchedulerException
  31.  
    */
  32.  
    private void scheduleJob1(Scheduler scheduler) throws SchedulerException{
  33.  
    /*
  34.  
    * 此处可以先通过任务名查询数据库,如果数据库中存在该任务,则按照ScheduleRefreshDatabase类中的方法,更新任务的配置以及触发器
  35.  
    * 如果此时数据库中没有查询到该任务,则按照下面的步骤新建一个任务,并配置初始化的参数,并将配置存到数据库中
  36.  
    */
  37.  
    JobDetail jobDetail = JobBuilder.newJob(ScheduledJob.class) .withIdentity("job1", "group1").build();
  38.  
    // 每5s执行一次
  39.  
    CronScheduleBuilder scheduleBuilder = CronScheduleBuilder.cronSchedule("0/5 * * * * ?");
  40.  
    CronTrigger cronTrigger = TriggerBuilder.newTrigger().withIdentity("trigger1", "group1") .withSchedule(scheduleBuilder).build();
  41.  
    scheduler.scheduleJob(jobDetail,cronTrigger);
  42.  
    }
  43.  
     
  44.  
    /**
  45.  
    * 配置Job
  46.  
    * @param scheduler
  47.  
    * @throws SchedulerException
  48.  
    */
  49.  
    private void scheduleJob2(Scheduler scheduler) throws SchedulerException{
  50.  
    JobDetail jobDetail = JobBuilder.newJob(ScheduledJob2.class) .withIdentity("job2", "group1").build();
  51.  
    CronScheduleBuilder scheduleBuilder = CronScheduleBuilder.cronSchedule("0/10 * * * * ?");
  52.  
    // 每10s执行一次
  53.  
    CronTrigger cronTrigger = TriggerBuilder.newTrigger().withIdentity("trigger2", "group1") .withSchedule(scheduleBuilder).build();
  54.  
    scheduler.scheduleJob(jobDetail,cronTrigger);
  55.  
    }
  56.  
    }

3、启动两个任务

  1.  
    @Configuration
  2.  
    @EnableScheduling
  3.  
    @Component
  4.  
    public class SchedulerListener {
  5.  
     
  6.  
    @Autowired
  7.  
    public SchedulerAllJob myScheduler;
  8.  
     
  9.  
    /**
  10.  
    * 启动的时候执行该方法,或者是使用ApplicationListener,在启动的时候执行该方法
  11.  
    * 具体使用见:http://blog.csdn.net/liuchuanhong1/article/details/77568187
  12.  
    * @throws SchedulerException
  13.  
    */
  14.  
    @Scheduled(cron="0 08 18 ? * *")
  15.  
    public void schedule() throws SchedulerException {
  16.  
    myScheduler.scheduleJobs();
  17.  
    }
  18.  
     
  19.  
    @Bean
  20.  
    public SchedulerFactoryBean schedulerFactoryBean(){
  21.  
    SchedulerFactoryBean schedulerFactoryBean = new SchedulerFactoryBean();
  22.  
    return schedulerFactoryBean;
  23.  
    }
  24.  
    }

4、测试结果如下

  1.  
    schedule job1 is running……………………………………
  2.  
    schedule job2 is running ……………………………………………………
  3.  
    schedule job1 is running……………………………………
  4.  
    schedule job1 is running……………………………………
  5.  
    schedule job2 is running ……………………………………………………
  6.  
    schedule job1 is running……………………………………
  7.  
    schedule job1 is running……………………………………
  8.  
    schedule job2 is running ……………………………………………………
  9.  
    schedule job1 is running……………………………………

spring boot整合quartz实现多个定时任务的更多相关文章

  1. spring boot 整合quartz ,job不能注入的问题

    在使用spring boot 整合quartz的时候,新建定时任务类,实现job接口,在使用@AutoWire或者@Resource时,运行时出现nullpointException的问题.显然是相关 ...

  2. spring boot 整合 quartz 集群环境 实现 动态定时任务配置【原】

    最近做了一个spring boot 整合 quartz  实现 动态定时任务配置,在集群环境下运行的 任务.能够对定时任务,动态的进行增删改查,界面效果图如下: 1. 在项目中引入jar 2. 将需要 ...

  3. Spring Boot整合Quartz实现定时任务表配置

    最近有个小项目要做,spring mvc下的task设置一直不太灵活,因此在Spring Boot上想做到灵活的管理定时任务.需求就是,当项目启动的时候,如果有定时任务则加载进来,生成schedule ...

  4. Spring Boot 整合Quartz定时器

    概述 项目需要定时器的调度管理,原来使用Spring Boot自带的定时器,但是不能后台动态的操作暂停.启动以及新增任务等操作,维护起来相对麻烦:最近研究了Quartz的框架,觉得还算不错,整理了一下 ...

  5. spring boot整合quartz定时任务案例

    1.运行环境 开发工具:intellij idea JDK版本:1.8 项目管理工具:Maven 4.0.0 2.GITHUB地址 https://github.com/nbfujx/springBo ...

  6. 【Spring Boot学习之六】Spring Boot整合定时任务&异步调用

    环境 eclipse 4.7 jdk 1.8 Spring Boot 1.5.2一.定时任务1.启动类添加注解@EnableScheduling 用于开启定时任务 package com.wjy; i ...

  7. spring boot 系列之八:SpringBoot处理定时任务

    项目经常会用到定时任务,springboot自然是可以通过整合相关组件来实现的. 目前常用的定时任务的实现有两种: 通过spring 自带的定时器任务@Schedule来实现 通过Quartz来实现 ...

  8. Spring Kafka和Spring Boot整合实现消息发送与消费简单案例

    本文主要分享下Spring Boot和Spring Kafka如何配置整合,实现发送和接收来自Spring Kafka的消息. 先前我已经分享了Kafka的基本介绍与集群环境搭建方法.关于Kafka的 ...

  9. spring boot+mybatis+quartz项目的搭建完整版

    1. 利用spring boot提供的工具(http://start.spring.io/)自动生成一个标准的spring boot项目架构 2. 因为这里我们是搭建spring boot+mybat ...

随机推荐

  1. RC4被JDK8默认禁用导致腾讯QQ邮箱无法访问

    7月29日开始,腾讯修改了邮箱的加密方式,导致我们线上的所有的腾讯代收.代发邮件的功能全部失效.解决方法在最后,如果需要可直接跳转至解决方法一节 问题出现 7月29日开始,线上的所有的腾讯代收.代发邮 ...

  2. C/C++基础----拷贝控制

    拷贝控制操作,有5个特殊成员函数copy ctor,copy =opt,move ctor,move =opt,dtor 有哪些地方会用到 拷贝初始化 除了=定义变量时 参数传递和函数返回时 花括号列 ...

  3. C#应用jstree实现无限级节点的方法

    下载jstree.js下载地址: http://jstree.com/ 当前下载版本: jsTree 3.3.1 第一步:下载完成后引用js+css <link href="~/plu ...

  4. javac命令和java命令

    要知道java是分两部分的:一个是编译,一个是运行. javac:负责的是编译的部分,当执行javac时,会启动java的编译器程序.对指定扩展名的.java文件进行编译. 生成了jvm可以识别的字节 ...

  5. PAT 乙级 1019 数字黑洞 (20) C++版

    1019. 数字黑洞 (20) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 给定任一个各位数字不完全相同的4位 ...

  6. Linux下的Mysql安装 & 配置

    Hive的数据,是存在HDFS里的.此外,hive有哪些数据库,每个数据库有哪些表,这样的信息称之为hive的元数据信息. 元数据信息不存在HDFS里.而是存在关系型数据库里,hive默认用的是der ...

  7. Java学习——this、this()、super 和 super()的使用

    编写程序:说明 this.super 和 super()的用法.程序首先定义 Point(点)类,然后创建点的子类 Line(线)),最后通过 LX7_3 类输出线段的长度. package Pack ...

  8. ie6下a标签click事件无法触发加载iframe

    ie6下a标签click事件无法触发加载iframe,把a换成span或者别的,就可以了

  9. 如何在eclipse 里面调试java.lang包的代码

    1.  在Eclipse中,Window->Preferences->Java->Compiler,确保以下选项都勾选上 2. 在Eclipse中,Window->Prefer ...

  10. Scrapy学习篇(五)之Spiders

    Spiders Spider类定义了如何爬取某个网站.包括了爬取的动作(例如:是否跟进链接)以及如何从网页的内容中提取结构化数据(爬取item).简而言之,Spider就是你定义爬取的动作及分析某个网 ...