博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
spring boot整合quartz实现多个定时任务
阅读量:4560 次
发布时间:2019-06-08

本文共 3283 字,大约阅读时间需要 10 分钟。

 

版权声明:本文为博主原创文章,转载请注明出处。 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……………………………………
  10.  

转载于:https://www.cnblogs.com/pejsidney/p/9894476.html

你可能感兴趣的文章
mongodb数据库---本地集合拷贝克隆、筛选剔除(转并学习)
查看>>
Python中的random模块
查看>>
WeQuant交易策略—EMA指标
查看>>
【算法笔记】B1033 旧键盘打字
查看>>
Flutter学习笔记
查看>>
java中类的组合机制
查看>>
git安装及使用
查看>>
mysql一个非常实用解决sql查询优化的函数explain
查看>>
图文讲解NTFS和FAT32硬盘下 asp.net 生成word 错误: 80070005 和 错误:8000401a 的解决方法...
查看>>
《学习》5连接查询(高级查询)
查看>>
arch更新pacman到4.0注意事项
查看>>
python日常—爬取豆瓣250条电影记录
查看>>
11.3NOIP模拟赛
查看>>
1.SDL介绍
查看>>
【重要更新】语言转换类编程工具Tangible系列本月又更新了!
查看>>
现场赛:开关灯问题
查看>>
codeforces A. Jeff and Rounding (数学公式+贪心)
查看>>
zoj 3462
查看>>
java多线程-信号量
查看>>
如何在Delphi XE2中使用Dynamic Web TWAIN
查看>>