一个实现类,简单的测试,打印出当前调度实例的名称和下次触发时间:
package com.christ.test.action;
import java.io.Serializable;
import java.util.Date;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;
import org.quartz.SchedulerException;
import org.springframework.scheduling.quartz.QuartzJobBean;
/**
* @author
*/
public class HelloJob extends QuartzJobBean implements Serializable {
/**
*
*/
static Log log = LogFactory.getLog(HelloJob.class);
/**
*
*/
public void helloJob() {
log.info("每分钟第10秒非集群测试" + (new Date().toString()));
}
@Override
protected void executeInternal(JobExecutionContext context) throws JobExecutionException {
try {
log.info(context.getScheduler().getSchedulerName() + "集群测试下一次运行时间应该为: "+ context.getTrigger().getNextFireTime());
// Scheduler sc = context.getScheduler();
// sc.shutdown();
} catch (SchedulerException e) {
e.printStackTrace();
}
}
}
然后就是配置好quartz.xml,这里包括非集群和集群的方法,非集群也可以用插件实现,不过要多个配置文件,我嫌麻烦就直接写这里了:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx" xmlns:context="http://www.springframework.org/schema/context"
xmlns:dwr="http://www.directwebremoting.org/schema/spring-dwr"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
http://www.directwebremoting.org/schema/spring-dwr
http://www.directwebremoting.org/schema/spring-dwr-3.0.xsd">
<!-- 集群任务 -->
<bean id="job" class="org.springframework.scheduling.quartz.JobDetailBean">
<property name="jobClass" value="com.christ.test.action.HelloJob" />
</bean>
<!-- 集群作业触发器 -->
<bean id="clusterJobTime" class="org.springframework.scheduling.quartz.CronTriggerBean">
<property name="jobDetail" ref="job" />
<!-- cron表达式 -->
<property name="cronExpression" value="30 * * * * ?" />
</bean>
<!-- 集群调度 -->
<bean name="clusterQuartzScheduler" lazy-init="false" class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
<!--启动时更新数据库中己存在的Job-->
<property name="overwriteExistingJobs" value="true"/>
<!-- 应用启动后启动QuartzScheduler -->
<property name="startupDelay" value="30"/>
<property name="triggers">
<list>
<ref bean="clusterJobTime" />
</list>
</property>
<property name="configLocation" value="classpath:quartz.properties"/>
</bean>
<!--非集群作业-->
<bean id="helloJob" class="com.christ.test.action.HelloJob"></bean>
<bean id="jobtest"
class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
<!-- 调用的类 -->
<property name="targetObject" ref="helloJob"/>
<!-- 调用类中的方法 -->
<property name="targetMethod" value="helloJob"/>
</bean>
<!-- 非集群作业触发器-->
<bean id="JobTime" class="org.springframework.scheduling.quartz.CronTriggerBean">
<property name="jobDetail" ref="jobtest" />
<!-- cron表达式 -->
<property name="cronExpression" value="10 * * * * ?" />
</bean>
<!-- 非集群调度 -->
<bean name="quartzScheduler" class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
<!-- 触发器 -->
<property name="triggers">
<list>
<ref bean="JobTime" />
</list>
</property>
</bean>
</beans>
分享到:
相关推荐
在实际应用中,你可能还会遇到如负载均衡、任务同步、节点间的通信等问题,需要对Quartz的API和原理有深入理解才能更好地应对。通过阅读官方文档、源码分析和实践操作,可以进一步掌握Quartz集群的精髓,提高系统...
在实际应用中,根据业务需求和环境的不同,可能还需要对Quartz的配置进行更深入的调整,例如设置调度器的线程池大小、调整触发器的优先级等。总之,理解和掌握这些SQL脚本以及Quartz集群的工作原理,是确保Quartz在...
在实际应用中,可能会使用如ZooKeeper这样的分布式协调服务来帮助Quartz集群管理状态。 在压缩包文件"oa_ssh"中,可能包含了项目的所有源代码、配置文件、数据库脚本等资源,开发者可以通过这些文件了解和学习SSH...
标题 "spring quartz 集群模式" 涉及到的是Spring框架与Quartz调度器在集群环境下的集成和配置。Quartz是一个开源任务...在实际应用中,需要结合数据库配置、集群设置以及Spring的整合来构建高效稳定的定时任务系统。
在IT行业中,Spring框架是Java应用开发中的基石,而Quartz则是广泛...通过上述步骤,你已经掌握了Spring集成Quartz集群配置的基本概念。在实践中,根据具体需求调整配置,可以实现高效、稳定且可扩展的任务调度系统。
5. **集群配置**:为了实现高可用的Quartz集群,你需要配置多个节点共享同一个数据库存储的作业和触发器信息。Quartz支持多种持久化策略,如JDBC、RAMJobStore等,选择数据库存储能保证在集群中的任务状态一致性。 ...
"quartz集群各种数据库建表脚本" 提供了在不同类型的数据库中创建Quartz集群所需的表结构。基于quartz2.2.1版本,这个脚本应该包含了创建必要的调度表,如QRTZ_JOB_DETAILS、QRTZ_TRIGGERS、QRTZ_SIMPLE_TRIGGERS等...
在构建Quartz集群时,为了实现高可用性和任务的分布式处理,需要在多个节点之间共享状态信息,这就涉及到数据库的支持。数据库在这里起到了存储作业和触发器信息的作用,确保在集群中的各个节点间能够正确协调和执行...
Quartz 是一个开源的作业调度框架,常用于在Java应用中执行定时任务。Spring 是一个广泛应用的Java企业级开发框架,它可以与Quartz紧密结合,...在实际应用中,需要根据业务需求调整配置,以达到最佳的性能和可靠性。
在提供的压缩包中,可能包含了一个简单的Quartz集群应用示例,源码通常会包括以下部分: - **Job类**:实现`org.quartz.Job`接口,定义具体的任务逻辑。 ```java public class MyJob implements Job { @Override ...
3. **监控和管理**: 实现对Quartz集群的监控,如任务状态、运行时性能等,以便及时发现和解决问题。 总结,Quartz+Spring的分布式集群调度方案能够帮助开发者构建稳定且可扩展的定时任务系统。通过合理配置和实践,...
文件“quartz集群完整应用实例 2.docx”可能包含了一个完整的Quartz集群配置示例,包括具体的Spring配置、Quartz配置以及可能的数据库脚本。通过阅读和分析这个文档,你可以获得更深入的理解和实践经验。 总之,...
7. **性能优化**:在实际应用中,可能会涉及Quartz集群的性能优化,比如调整并发执行的Job数量,或者设置合适的调度策略以避免过多的数据库交互。 8. **监控与管理**:Quartz提供了Web界面(如QConsole)用于监控和...
至于博文链接中的内容,虽然无法直接查看,但通常会包含如何在实际项目中设置Quartz集群和Spring Data集成的详细步骤,包括配置示例、代码示例以及可能遇到的问题和解决方案。 在使用过程中,可能会遇到如任务并发...
Quartz是开源的作业调度框架,常用于Java应用程序中,以执行定时任务。在分布式环境中,Quartz集群能够实现任务的高可用性...在实际应用中,根据具体业务需求进行适当的优化和调整,可以进一步提高系统的性能和可靠性。
Quartz集群是基于Java的开源任务调度框架,用于在分布式环境中执行定时任务。它提供了高度可配置性、...博客文章中的内容可能详细解析了如何设置、配置和管理Quartz集群,以及在实际项目中应用Quartz的技巧和最佳实践。
#### 二、Quartz集群调度概述 Quartz提供了多种方式来实现集群调度,包括但不限于单独启动JobServer、使用Spring + Quartz架构以及利用Quartz本身的集群支持。这些方案各有优势,适用于不同的场景需求。 ##### 1. ...
Quartz集群则是在单个Quartz实例的基础上,通过多台服务器的协作来提高系统的可用性和容错性,确保即使在单个节点故障时,作业仍然能够被正确地调度和执行。 在Quartz集群中,每个节点都是一个独立的Quartz ...