此版本仍在开发中,尚未被视为稳定版本。对于最新的稳定版本,请使用 Spring Boot 3.4.0spring-doc.cadn.net.cn

Quartz 调度器

Spring Boot 为使用 Quartz 调度程序提供了多种便利,包括spring-boot-starter-quartz起动机。 如果 Quartz 可用,则Scheduler是自动配置的(通过SchedulerFactoryBeanabstraction)。spring-doc.cadn.net.cn

以下类型的 bean 将被自动选取并与Scheduler:spring-doc.cadn.net.cn

默认情况下,内存中的JobStore被使用。 但是,如果DataSourcebean 在您的应用程序中可用,并且如果spring.quartz.job-store-type属性,如以下示例所示:spring-doc.cadn.net.cn

spring.quartz.job-store-type=jdbc
spring:
  quartz:
    job-store-type: "jdbc"

使用 JDBC 存储时,可以在启动时初始化架构,如以下示例所示:spring-doc.cadn.net.cn

spring.quartz.jdbc.initialize-schema=always
spring:
  quartz:
    jdbc:
      initialize-schema: "always"
默认情况下,使用 Quartz 库提供的标准脚本检测和初始化数据库。 这些脚本会删除现有表,并在每次重启时删除所有触发器。 也可以通过设置spring.quartz.jdbc.schema财产。

要让 Quartz 使用DataSource除了应用程序的 mainDataSource,声明一个DataSourcebean,为其@Beanmethod 替换为@QuartzDataSource. 这样做可以确保特定于 Quartz 的DataSourceSchedulerFactoryBean以及 schema 初始化。 同样,要让 Quartz 使用TransactionManager除了应用程序的 mainTransactionManager声明一个TransactionManagerbean,为其@Beanmethod 替换为@QuartzTransactionManager.spring-doc.cadn.net.cn

默认情况下,通过配置创建的作业不会覆盖已从持久性作业存储中读取的已注册作业。 要启用覆盖现有作业定义,请将spring.quartz.overwrite-existing-jobs财产。spring-doc.cadn.net.cn

可以使用 Quartz Scheduler 配置进行自定义spring.quartzproperties 和SchedulerFactoryBeanCustomizerbean,它允许以编程方式SchedulerFactoryBean定制。 高级 Quartz 配置属性可使用spring.quartz.properties.*.spring-doc.cadn.net.cn

特别是,Executorbean 与调度器无关,因为 Quartz 提供了一种通过spring.quartz.properties. 如果需要自定义任务执行程序,请考虑实现SchedulerFactoryBeanCustomizer.

Job 可以定义 setter 来注入数据映射属性。 常规 bean 也可以以类似的方式注入,如以下示例所示:spring-doc.cadn.net.cn

import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;

import org.springframework.scheduling.quartz.QuartzJobBean;

public class MySampleJob extends QuartzJobBean {

	// fields ...

	private MyService myService;

	private String name;


	// Inject "MyService" bean
	public void setMyService(MyService myService) {
		this.myService = myService;
	}

	// Inject the "name" job data property
	public void setName(String name) {
		this.name = name;
	}

	@Override
	protected void executeInternal(JobExecutionContext context) throws JobExecutionException {
		this.myService.someMethod(context.getFireTime(), this.name);
	}

}
import org.quartz.JobExecutionContext
import org.springframework.scheduling.quartz.QuartzJobBean

class MySampleJob : QuartzJobBean() {

	// fields ...

	private var myService: MyService? = null

	private var name: String? = null

	// Inject "MyService" bean
	fun setMyService(myService: MyService?) {
		this.myService = myService
	}

	// Inject the "name" job data property
	fun setName(name: String?) {
		this.name = name
	}

	override fun executeInternal(context: JobExecutionContext) {
		myService!!.someMethod(context.fireTime, name)
	}

}