一、Quartz作业管理和存储方式简介:
作业一旦被调度,调度器需要记住并且跟踪作业和它们的执行次数。如果你的作业是30分钟后或每30秒调用,这不是很有用。事实上,作业执行需要非常准确和即时调用在被调度作业上的execute()方法。Quartz通过一个称之为作业存储(JobStore)的概念来做作业存储和管理。
Quartz提供两种基本作业存储类型。第一种类型叫做RAMJobStore,它利用通常的内存来持久化调度程序信息。这种作业存储类型最容易配置、构造和运行。对许多应用来说,这种作业存储已经足够了。然而,因为调度程序信息是存储在被分配给JVM的内存里面,所以,当应用程序停止运行时,所有调度信息将被丢失。如果你需要在重新启动之间持久化调度信息,则RAMJobStore就满足不了你的需求,现在第二种类型的作业存储就出现了。 第二种类型的作业存储实际上提供两种不同的实现,但两种实现一般都称为JDBC作业存储。两种JDBC作业存储都需要JDBC驱动程序和后台数据库来持久化调度程序信息。这两种类型的不同在于你是否想要控制数据库事务或这释放控制给应用服务器例如BEA's WebLogic或Jboss。这类似于J2EE领域中,Bean管理的事务和和容器管理事务之间的区别。 这两种JDBC作业存储是: 1、JobStoreTX:当你想要控制事务或工作在非应用服务器环境中时使用 2、JobStoreCMT:当你工作在应用服务器环境中和想要容器控制事务时使用。
JDBC作业存储为需要调度程序维护调度信息的用户而设计。
二、RAMJobStore VS JDBC作业存储
三、配置:
1、RAMJobStore配置:
- #============================================================================
- # Configure RAMJobStore
- #============================================================================
- org.quartz.jobStore.class = org.quartz.simpl.RAMJobStore
2、JDBC存储配置:
- #============================================================================
- # Configure JobStore
- #============================================================================
- #===========================
- #Configure JDBC-JobStoreTX
- #===========================
- org.quartz.jobStore.class = org.quartz.impl.jdbcjobstore.JobStoreTX
- org.quartz.jobStore.driverDelegateClass = org.quartz.impl.jdbcjobstore.oracle.OracleDelegate
- org.quartz.jobStore.tablePrefix = QRTZ_
- org.quartz.jobStore.dataSource = myDS
- org.quartz.jobStore.useProperties = false
- #============================
- # Configure DataSource
- #============================
- org.quartz.dataSource.myDS.driver = ******
- org.quartz.dataSource.myDS.URL = ******
- org.quartz.dataSource.myDS.user = user
- org.quartz.dataSource.myDS.password = password
- org.quartz.dataSource.myDS.maxConnections = 10
四、总结
两种工作方式各有利弊,RAMJobStore存在于运行内存中,执行起来效率高速度快毋庸置疑,可是,我们也都明白,当我一段程序执行完毕或者是关机重启,内存数据清空重新分配的时候,我们的一些数据就没有了,也就是说,这种方式无法随时随地瞎持久化我们的调度信息。而结合JDBC作业存储方式来看,我们依靠第三方的数据库来持久化我们的调度信息,虽然在效率和速度上有所不及,但是贵在能随时随地适应各种情况的调取我们的调度信息。总而言之就是各有利弊,适时而用,取最符合要求的作业存储方式。