Spring Boot 整合 Quartz

简介:

配置

pom

Spring Boot 使用的是2.1.6.RELEASE,依赖中增加如下配置

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

application.properties

调度器可以和springboot公用数据源

#使用数据库固化调度信息
spring.quartz.job-store-type=jdbc
#调度器名称
spring.quartz.scheduler-name=MyScheduler
#不重新创建数据表
spring.quartz.jdbc.initialize-schema=never
#线程数量
spring.quartz.properties.org.quartz.threadPool.threadCount = 50
#持久化实现
spring.quartz.properties.org.quartz.jobStore.class=org.quartz.impl.jdbcjobstore.JobStoreTX
#数据库方言StdJDBCDelegate 
spring.quartz.properties.org.quartz.jobStore.driverDelegateClass=org.quartz.impl.jdbcjobstore.StdJDBCDelegate 

java代码

任务:实现Job接口即可

public interface Job {
    //context中包含当前任务关联的信息 
    //JobExecutionException 当任务执行失败时可以通过配置来控制是否继续执行等操作
    void execute(JobExecutionContext context) throws JobExecutionException;
}

调度器:在service中注入Scheduler即可,Scheduler是调度器整体管理包括暂停任务,更新任务,恢复任务等

需求以及解决方法

每个任务使用相同上下文即JobData
继承Job的java类上增加@PersistJobDataAfterExecution,@DisallowConcurrentExecution注解,通常这两个注解配合使用

  • @PersistJobDataAfterExecution:在任务执行后固化JobData至数据库
  • @DisallowConcurrentExecution:避免同一个组的同一个任务并发执行以免JobData混乱

更新JobData至当前任务

   //jobDetail 任务信息
   JobDetail jobDetail = scheduler.getJobDetail(JobKey.jobKey(job.getName(), job.getGroup()));
   jobDetail.getJobDataMap().put("aaa", "bbb");
   CronTrigger trigger = (CronTrigger) scheduler.getTrigger(TriggerKey.triggerKey(job.getName(), job.getGroup()));
   Set<Trigger> triggers = new HashSet<>();
   triggers.add(trigger);
   //true 就是替换数据库中JobDataMap
   scheduler.scheduleJob(jobDetail,triggers,true);

任务控制

  • 暂停任务:scheduler.pauseJob(jobKey)
  • 恢复任务:scheduler.resumeJob(jobKey)
  • 立即执行任务:scheduler.triggerJob(jobKey)
  • 执行中的任务:
List<JobExecutionContext> executingJobs = scheduler.getCurrentlyExecutingJobs()
//获取具体任务信息
JobDetail jobDetail = executingJob.getJobDetail();
  • 查询任务
   //依据分组查询,如需其他查找查看api中实现了org.quartz.Matcher接口的类即可
   GroupMatcher<JobKey> matcher = GroupMatcher.groupContains(groupKeyword);
   Set<JobKey> jobKeys = scheduler.getJobKeys(matcher);
   //通过JobKey获取调度器中具体任务以及相关信息 
   scheduler.getJobDetail(jobKey); 

参考资料

https://eelve.com/archives/springbootstarterquartzs

http://www.quartz-scheduler.org/

https://www.w3cschool.cn/quartz_doc/

目录
相关文章
|
26天前
|
存储 运维 安全
Spring运维之boot项目多环境(yaml 多文件 proerties)及分组管理与开发控制
通过以上措施,可以保证Spring Boot项目的配置管理在专业水准上,并且易于维护和管理,符合搜索引擎收录标准。
39 2
|
2月前
|
SQL JSON Java
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和PageHelper进行分页操作,并且集成Swagger2来生成API文档,同时定义了统一的数据返回格式和请求模块。
66 1
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
|
2月前
|
缓存 NoSQL Java
Springboot自定义注解+aop实现redis自动清除缓存功能
通过上述步骤,我们不仅实现了一个高度灵活的缓存管理机制,还保证了代码的整洁与可维护性。自定义注解与AOP的结合,让缓存清除逻辑与业务逻辑分离,便于未来的扩展和修改。这种设计模式非常适合需要频繁更新缓存的应用场景,大大提高了开发效率和系统的响应速度。
72 2
|
4月前
|
Java 关系型数据库 MySQL
SpringBoot 集成 Quartz + MySQL
SpringBoot 集成 Quartz + MySQL
121 1
|
6月前
|
运维 Java 关系型数据库
Spring运维之boot项目bean属性的绑定读取与校验
Spring运维之boot项目bean属性的绑定读取与校验
57 2
|
6月前
|
存储 运维 Java
Spring运维之boot项目开发关键之日志操作以及用文件记录日志
Spring运维之boot项目开发关键之日志操作以及用文件记录日志
68 2
|
6月前
|
Java Maven
springboot项目打jar包后,如何部署到服务器
springboot项目打jar包后,如何部署到服务器
443 1
|
6月前
|
XML 运维 Java
Spring运维之boot项目打包jar和插件运行并且设置启动时临时属性和自定义配置文件
Spring运维之boot项目打包jar和插件运行并且设置启动时临时属性和自定义配置文件
57 1
|
6月前
springboot2.4.5使用pagehelper分页插件
springboot2.4.5使用pagehelper分页插件
165 0
|
6月前
|
SQL API 调度
Springboot2.4.5集成Quartz实现动态任务数据持久化-不怕重启服务
Springboot2.4.5集成Quartz实现动态任务数据持久化-不怕重启服务
247 0