java 定时器qz xm配置_Spring Boot集成quartz实现定时任务并支持切换任务数据源

org.quartz实现定时任务并自定义切换任务数据源

在工作中经常会需要使用到定时任务处理各种周期性的任务,org.quartz是处理此类定时任务的一个优秀框架。随着项目一点点推进,此时我们并不满足于任务仅仅是定时执行,我们还想要对任务进行更多的控制,随时能对任务进行人为干预,就需要对quartz有更深入的了解。而随着微服务的流行,项目中多数据源的情况也越来越常见,在定时任务中集成多数据源切换的功能也需要集成进来。

集成quartz实现定时任务

quartz中实现定时任务需要了解的基本概念

Job

通过实现Job类,在实现方法中写我们具体想要定时任务完成的工作,然后交给quartz管理。

JobDetail

Job只负责实现具体任务,所以还需要借助JobDetail来存储一些描述Job的基本信息。

Quartz JobBuilder

为构造JobDetail实体提供的builder-style API。你可以这样使用它来构建一个JobDetail:

@Bean

public JobDetail jobDetail() {

return JobBuilder.newJob().ofType(SampleJob.class)

.storeDurably()

.withIdentity("Qrtz_Job_Detail")

.withDescription("Invoke Sample Job service...")

.build();

}

Spring JobDetailFactoryBean

在Spring中配置JobDetail的方式:

@Bean

public JobDetailFactoryBean jobDetail() {

JobDetailFactoryBean jobDetailFactory = new JobDetailFactoryBean();

jobDetailFactory.setJobClass(SampleJob.class);

jobDetailFactory.setDescription("Invoke Sample Job service...");

jobDetailFactory.setDurability(true);

return jobDetailFactory;

}

Trigger

触发器,代表一个调度参数的配置,什么时候去调度:

@Bean

public Trigger trigger(JobDetail job) {

return TriggerBuilder.newTrigger().forJob(job)

.withIdentity("Qrtz_Trigger")

.withDescription("Sample trigger")

.withSchedule(simpleSchedule().repeatForever().withIntervalInHours(1))

.build();

}

Scheduler

调度器,通过Job和Trigger来注册一个调度器:

@Bean

public Scheduler scheduler(Trigger trigger, JobDetail job) {

StdSchedulerFactory factory = new StdSchedulerFactory();

factory.initialize(new ClassPathResource("quartz.properties").getInputStream());

Scheduler scheduler = factory.getScheduler();

scheduler.setJobFactory(springBeanJobFactory());

scheduler.scheduleJob(job, trigger);

scheduler.start();

return scheduler;

}

给系统添加一个Job

在quartz中Job就是我们需要去执行的任务,由Scheduler调度器负责调度任务们依靠制定好的Trigger来定时执行任务。

因此首先我们需要结合以上基础给系统添加一个Job。

addJob

public void addJob(BaseJob job) throws SchedulerException {

/** 创建JobDetail实例,绑定Job实现类

* JobDetail 表示一个具体的可执行的调度程序,job是这个可执行调度程序所要执行的内容

* 另外JobDetail还包含了这个任务调度的方案和策略**/

// 指明job的名称,所在组的名称,以及绑定job类

JobDetail jobDetail = JobBuilder.newJob(job.getBeanClass())

.withIdentity(job.getJobKey())

.withDescription(job.getDescription())

.usingJobData(job.getDataMap())

.build();

/**

* Trigger代表一个调度参数的配置,什么时候去调度

*/

//定义调度触发规则, 使用cronTrigger规则

Trigger trigger = TriggerBuilder.newTrigger()

.withIdentity(job.getJobName(),job.getJobGroup())

.withSchedule(CronScheduleBuilder.cronSchedule(job.getCronExpression()))

.startNow()

.build();

//将任务和触发器注册到任务调度中去

scheduler.scheduleJob(jobDetail,trigger);

//判断调度器是否启动

if(!scheduler.isStarted()){

scheduler.start();

}

log.info(String.format("定时任务:%s.%s-已添加到调度器!", job.getJobGroup(),job.getJobName()));

}

首先需要定

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值