Quartz学习研究(三):一个最基本的Quartz、Spring集群项目(附项目源代码)

1、前言:上篇文章已经介绍了quartz与spring集成,这篇文章会继续将上个项目部署到集群环境中。集群环境可解决服务器宕机数据丢失、多服务器间的定时冲突等问题。Quartz中的集群概念其实并不是真正服务器之间的通讯,而是通过同一套quartz的数据库来进行管理

2、从官网或者quartz的jar包中找到tables_mysql.sql(以本次项目为例,如果是其他数据库找到对应的文件即可,quartz已经全部备好),并在数据库中进行quartz表的创建。注意:这套数据库表创建以后结构基本不变,所以为了方便管理,减少出错率,建议单独开辟一片区域创建这些表。

3、同上篇文章中配Spring一样,首先初始化一个任务Job,也就是具体要做的业务(本次是在控制台打印出HelloWorld和当前时间)。不过要注意:由于是部署到集群环境中,而集群环境是通过数据库表进行管理,需要序列化到数据库中,所以这里HelloWorld类必须实现序列化接口Serializable。

[java]  view plain copy
  1. package com.telek.quartz;  
  2.   
  3. import java.io.Serializable;  
  4. import java.util.Date;  
  5.   
  6. /** 
  7.  * Description:具体业务代码 
  8.  * HelloWorld.java Create on 2012-11-23 上午9:33:55  
  9.  * @author 张景 
  10.  * @version 1.0 
  11.  * Copyright (c) 2012 telek. All Rights Reserved. 
  12.  */  
  13. public class HelloWorld implements Serializable{  
  14.   
  15.     /** 
  16.      *  
  17.      */  
  18.     private static final long serialVersionUID = 1L;  
  19.   
  20.     public void sayHello(){  
  21.         System.out.println("Hello World : " + new Date());  
  22.     }  
  23.   
  24. }  

4、同上篇文章一样配置applicationContext-quartz.xml文件

[java]  view plain copy
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN 2.0//EN" "http://www.springframework.org/dtd/spring-beans-2.0.dtd">  
  3.   
  4. <beans>  
  5.     <bean id="helloWorld" class="com.telek.quartz.HelloWorld"></bean>  
  6.     <!-- 实例化一个具体任务 -->  
  7.     <bean id="helloWorldJobDetail"  
  8.         class="com.telek.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean ">  
  9.         <property name="targetObject" ref="helloWorld" />  
  10.         <property name="targetMethod" value="sayHello" />  
  11.     </bean>  
  12.     <!-- 为这个任务添加触发器 -->  
  13.     <bean id="helloWorldTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean">  
  14.         <property name="jobDetail" ref="helloWorldJobDetail" />  
  15.         <property name="cronExpression" value="0/8 * * * * ?" />  
  16.     </bean>  
  17.     <!-- 将具体任务和触发器部署到调度器scheduler上 -->  
  18.     <bean name="quartzScheduler"  
  19.         class="org.springframework.scheduling.quartz.SchedulerFactoryBean">  
  20.         <property name="applicationContextSchedulerContextKey" value="applicationContextKey" />  
  21.         <property name="triggers">  
  22.             <list>  
  23.                 <!-- 此处可添加多个触发器 -->  
  24.                 <ref bean="helloWorldTrigger" />  
  25.             </list>  
  26.         </property>  
  27.     </bean>  
  28. </beans>  

5、同上片文章一样配置web.xml文件

[java]  view plain copy
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  3.     xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"  
  4.     xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"  
  5.     version="3.0">  
  6.     <welcome-file-list>  
  7.         <welcome-file>index.jsp</welcome-file>  
  8.     </welcome-file-list>  
  9.     <context-param>  
  10.         <param-name>contextConfigLocation</param-name>  
  11.         <param-value>  
  12.             /WEB-INF/classes/applicationContext-quartz.xml  
  13.         </param-value>  
  14.     </context-param>  
  15.     <listener>  
  16.         <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>  
  17.     </listener>  
  18. </web-app>  

6、配置quartz.properties,本步骤是集群环境部署的核心步骤。

[java]  view plain copy
  1. #==============================================================      
  2. #Configure Main Scheduler Properties      
  3. #==============================================================       
  4. org.quartz.scheduler.instanceName = quartzScheduler    
  5. org.quartz.scheduler.instanceId = AUTO    
  6.   
  7. #==============================================================      
  8. #Configure ThreadPool      
  9. #==============================================================     
  10. org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPool    
  11. org.quartz.threadPool.threadCount = 10    
  12. org.quartz.threadPool.threadPriority = 5    
  13. org.quartz.threadPool.threadsInheritContextClassLoaderOfInitializingThread = true   
  14.   
  15. #==============================================================      
  16. #Configure JobStore      
  17. #==============================================================     
  18. org.quartz.jobStore.class = org.quartz.impl.jdbcjobstore.JobStoreTX    
  19. org.quartz.jobStore.driverDelegateClass = org.quartz.impl.jdbcjobstore.StdJDBCDelegate    
  20. org.quartz.jobStore.tablePrefix = QRTZ_    
  21. org.quartz.jobStore.isClustered = true    
  22. org.quartz.jobStore.clusterCheckinInterval = 20000      
  23. org.quartz.jobStore.dataSource = myDS    
  24.      
  25. #==============================================================      
  26. #Configure DataSource    (此处填你自己的数据库连接信息)  
  27. #==============================================================     
  28. org.quartz.dataSource.myDS.driver = com.mysql.jdbc.Driver    
  29. org.quartz.dataSource.myDS.URL = jdbc\:mysql\://10.10.10.213\:3306/quartz?useUnicode\=true&characterEncoding\=UTF-8    
  30. org.quartz.dataSource.myDS.user = cloudserver    
  31. org.quartz.dataSource.myDS.password = telek    
  32. org.quartz.dataSource.myDS.maxConnections =30    

7、将web部署到tomcat服务器(其他服务器也行)。

8、观察结果:在控制台上在每分钟6秒的倍数会打印出helloWorld和当前时间。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值