快速上手Quartz实现定时任务

简介: 快速上手Quartz实现定时任务

先上图

Quartz实现定时任务

Quartz是一个定时任务框架,相较于JDK和Spring的定时任务线程池,其功能更加多样,更适合分布式系统(因为引入了数据库)。

Quartz的底层

  1. 在java中常见的定时调度方案有:ScheduledExecutorService和quartz两种方案。其本质上都是通过native的wait方法来实现的.
  2. quartz定时调度是通过Object.wait方式(native方法)实现的,其本质是通过操作系统的时钟来实现的。

Quartz的核心组件

  • Scheduler:调度器。控制任务调度
  • Trigger: 触发器。决定什么时候来执行任务。
  • JobDetail :定义任务细节
  • Job:任务的执行逻辑

代码(易懂)

依赖引入

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

编写要执行的定时任务

@Component
public class MessageDayJob implements Job {
    //注入相关依赖
    //@Autowired
    //A a;
    private int intervalDay = 30;
    @Override
    public void execute(JobExecutionContext context) throws JobExecutionException {
        System.out.println("执行任务");
        // 任务的具体逻辑
        //a.test();
        System.out.println("结束任务");
    }
}

定时任务配置文件

@Configuration
public class QuartzConfig {
    @Bean
    public JobDetailFactoryBean messageJobDetail(){
        JobDetailFactoryBean factoryBean = new JobDetailFactoryBean();
        factoryBean.setJobClass(MessageDayJob.class);
        factoryBean.setName("messageJob");
        factoryBean.setGroup("messageJobGroup");
        factoryBean.setDurability(true);// 持续保存
        factoryBean.setRequestsRecovery(true);
        return factoryBean;
    }
    @Bean
    public CronTriggerFactoryBean messageTrigger(JobDetail messageJobDetail){
        CronTriggerFactoryBean factoryBean = new CronTriggerFactoryBean();
        factoryBean.setJobDetail(messageJobDetail);
        factoryBean.setName("messageTrigger");
        factoryBean.setGroup("messageTriggerGroup");
        factoryBean.setCronExpression("0 0 2 * * ?");// 每天凌晨2点执行
        factoryBean.setJobDataMap(new JobDataMap());
        return factoryBean;
    }
}

持久化到数据库

在上述代码中,我们并没有编写数据库相关配置。Quartz会默认将任务数据保存到JVM内存中,但是当服务器挂了后,任务数据就会消失。而且,在服务器集群中,该数据难以统一。所以我们需要引入数据库。

srping:
    quartz:
      # 将任务等保存化到数据库
      job-store-type: jdbc
      # 程序结束时会等待quartz相关的内容结束
      wait-for-jobs-to-complete-on-shutdown: true
      # QuartzScheduler启动时更新己存在的Job,这样就不用每次修改targetObject后删除qrtz_job_details表对应记录
      overwrite-existing-jobs: true
      # 这里居然是个map,搞得智能提示都没有,佛了
      properties:
        org:
          quartz:
            # scheduler相关
            scheduler:
              # scheduler的实例名
              instanceName: scheduler
              instanceId: AUTO
            # 持久化相关
            jobStore:
              class: org.springframework.scheduling.quartz.LocalDataSourceJobStore
              driverDelegateClass: org.quartz.impl.jdbcjobstore.StdJDBCDelegate
              # 表示数据库中相关表是QRTZ_开头的
              tablePrefix: QRTZ_
              useProperties: false
            # 线程池相关
            threadPool:
              class: org.quartz.simpl.SimpleThreadPool
              # 线程数
              threadCount: 10
              # 线程优先级
              threadPriority: 5
              threadsInheritContextClassLoaderOfInitializingThread: true


相关文章
|
6月前
|
存储 NoSQL Java
【十】springboot整合quartz实现定时任务优化
【十】springboot整合quartz实现定时任务优化
113 0
|
6月前
|
缓存 Java 数据挖掘
SpringBoot整合定时任务技术Quartz
SpringBoot整合定时任务技术Quartz
105 0
|
6月前
|
SQL Java 调度
SpringBoot 整合 Quartz 定时任务框架
SpringBoot 整合 Quartz 定时任务框架
153 0
|
存储 开发框架 Java
分布式定时任务框架Quartz总结和实践(1)
Quartz是OpenSymphony开源组织在Job scheduling领域又一个开源项目,它可以与J2EE与J2SE应用程序相结合也可以单独使用。Quartz可以用来创建简单或为运行十个,百个,甚至是好几万个Jobs这样复杂的程序。Jobs可以做成标准的Java组件或 EJBs。
188 0
|
存储 Oracle Java
如何使用Quartz框架来实现任务调度?
如何使用Quartz框架来实现任务调度?
106 0
|
SQL 存储 Java
SpringBoot集成Quartz(定时任务)
SpringBoot集成Quartz(定时任务)
SpringBoot集成Quartz(定时任务)
|
Java 调度 Maven
定时任务组件Quartz
定时任务组件Quartz
定时任务组件Quartz
|
存储 运维 Java
分布式定时任务-QuartzJava编程
分布式定时任务-QuartzJava编程
分布式定时任务-QuartzJava编程
|
存储 运维 Java
分布式定时任务-Quartz
分布式定时任务-Quartz
分布式定时任务-Quartz
|
开发者 微服务
项目中整合定时任务 | 学习笔记
快速学习 项目中整合定时任务
122 0