spring quartz学习总结: cluster的配置和示例

本文介绍了Spring Quartz集群配置,通过集群可以解决单点故障和提高任务处理能力。配置包括设置scheduler实例、线程池、JobStore等,并提供了API和Spring配置示例。集群通过数据库锁机制保证任务在单一节点执行,实现负载均衡。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

转自:http://shmilyaw-hotmail-com.iteye.com/blog/2169156


简介

    在前面一篇文章里我们讨论了quartz和spring quartz的基本流程以及配置,这里针对一些quartz应用的场景和配置重点解读一下quartz的cluster配置和应用。

 

cluster配置

    在前面的执行quartz任务的环境里,我们都是在单独的一台机器上执行任务。这种单点执行的方式存在着一些问题。比如说,如果需要执行的任务量比较大,单台机器处理不过来。另外,如果这单独的节点失效了,整个节点上执行的所有任务也就都失败了。至少从这两点来说,如果我们要解决些问题的话,就需要考虑去除单点失效的问题并使用负载均衡来提高性能。

    说了这么多,其实在quartz里采用cluster模式的配置就是来解决上述问题的。quartz的cluster配置模型和我们传统的一些cluster系统模型有点不一样。一般的系统我们可能会考虑用LVS, keepalived等之类的东西来配,而这里是采用一个集中的数据库来保证负载均衡。它的配置模型如下:

 

    这种模型是怎么保证系统的高可用性和性能的呢?在这里,因为每个节点都执行不同的job,我们必须保证对于给定的任务只是在单独的一个节点上执行。所以当cluster里最先能够抢占到该任务的节点执行的时候,它会对数据库里对应这个任务的行加锁,然后后续的就不能再去占用了。通过利用锁的机制,这里也比较容易实现一个负载均衡,每次节点只要去取到那些没有被加锁的任务执行就可以了。关于quartz的内部执行细节会在后续的文章里描述。

   很明显,如果要在一个集群的模式下设置多个节点,每个节点必然会执行一到多个任务。这些任务的分配和执行情况需要记录和跟踪。同时怎么来调度资源协调它们也是一个需要考虑的问题。好在quartz里面已经提供了一些默认的配置支持,比如线程池和数据库连接池。一个典型的示例配置如下:

 

 

Properties代码   收藏代码
  1. #============================================================================       
  2. # Configure Main Scheduler Properties         
  3. #============================================================================       
  4. org.quartz.scheduler.instanceName = MyClusteredScheduler       
  5. org.quartz.scheduler.instanceId = AUTO       
  6. #============================================================================       
  7. # Configure ThreadPool         
  8. #============================================================================       
  9. org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPool       
  10. org.quartz.threadPool.threadCount = 25       
  11. org.quartz.threadPool.threadPriority = 5       
  12. #============================================================================       
  13. # Configure JobStore         
  14. #============================================================================       
  15. org.quartz.jobStore.misfireThreshold = 60000       
  16. org.quartz.jobStore.class = org.quartz.impl.jdbcjobstore.JobStoreTX       
  17. org.quartz.jobStore.driverDelegateClass =  
  18. org.quartz.impl.jdbcjobstore.oracle.OracleDelegate       
  19. org.quartz.jobStore.useProperties = false  
  20. org.quartz.jobStore.dataSource = myDS       
  21. org.quartz.jobStore.tablePrefix = QRTZ _     
  22. org.quartz.jobStore.isClustered = true  
  23. org.quartz.jobStore.clusterCheckinInterval = 20000       
  24. #============================================================================       
  25. # Configure Datasources         
  26. #============================================================================       
  27. org.quartz.dataSource.myDS.driver = oracle.jdbc.driver.OracleDriver       
  28. org.quartz.dataSource.myDS.URL = jdbc:oracle:thin:@polarbear:1521:dev       
  29. org.quartz.dataSource.myDS.user = quartz       
  30. org.quartz.dataSource.myDS.password = quartz       
  31. org.quartz.dataSource.myDS.maxConnections = 5       
  32. org.quartz.dataSource.myDS.validationQuery=select 0 from dual  
   因为需要配置成集群的模式,这里所有的任务数据需要记录到数据库中间。而以往默认创建的scheduler都是将任务数据记录在ramstore里,也就是这些数据都保存在内存中。另外,既然在多个节点中执行任务,每个任务执行的时间长短已经启动的时间点都不一样。所以需要为它们安排一个线程池来方便调度。同时,多个节点的更新都要访问数据库,所以这里对数据库的连接也最好使用连接池。前面的示例中使用了oracle的thin连接,并将线程池的容量配置成25个。

 

  到这里,cluster的基本配置已经差不多了。我们来结合具体的示例看看配置运行的结果。

 

示例

quartz api示例

 

  我们可以开始第一个最简单的示例,在这个示例里先不使用任何spring相关的配置,而是用原生的quartz api。首先创建一个maven工程SimpleQuartzCluster, 其pom.xml文件如下:

 

 

Xml代码   收藏代码
  1. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  2.   xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">  
  3.   <modelVersion>4.0.0</modelVersion>  
  4.   
  5.   <groupId>com.chanjet.chanapp</groupId>  
  6.   <artifactId>SimpleQuartzCluster</artifactId>  
  7.   <version>0.0.1-SNAPSHOT</version>  
  8.   <packaging>jar</packaging>  
  9.   
  10.   <name>SimpleQuartzCluster</name>  
  11.   <url>http://maven.apache.org</url>  
  12.   
  13.   <properties>  
  14.     <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>  
  15.     <junit.version>4.11</junit.version>  
  16.     <quartz.version>2.1.6</quartz.version>  
  17.     <mysql.connector.version>5.1.10</mysql.connector.version>  
  18.   </properties>  
  19.   
  20.   <dependencies>  
  21.     <dependency>  
  22.         <groupId>org.quartz-scheduler</groupId>  
  23.         <artifactId>quartz</artifactId>  
  24.         <version>${quartz.version}</version>  
  25.     </dependency>  
  26.   
  27.     <dependency>  
  28.         <groupId>mysql</groupId>  
  29.         <artifactId>mysql-connector-java</artifactId>  
  30.         <version>${mysql.connector.version}</version>  
  31.     </dependency>  
  32.           
  33.     <dependency>  
  34.       <groupId>junit</groupId>  
  35.       <artifactId>junit</artifactId>  
  36.       <version>${junit.version}</version>  
  37.       <scope>test</scope>  
  38.     </dependency>  
  39.   </dependencies>  
  40. </project>  
   因为考虑到后面我们将cluster的数据保存到mysql数据库中,所以这里引入了mysql-connector,在实际的应用中可以引入需要的库。

 

  和原来的套路一样,我们先定义一个简单的job实现:

 

 

Java代码   收藏代码
  1. package com.chanjet.chanapp;  
  2.   
  3. import org.quartz.Job;  
  4. import org.quartz.JobExecutionContext;  
  5. import org.quartz.JobExecutionException;  
  6.   
  7. public class SimpleJob implements Job {  
  8.   
  9.     public void execute(JobExecutionContext context) throws JobExecutionException {  
  10.         System.out.println("Job executed...");  
  11.     }  
  12. }  
   简单,不解释。

 

  然后我们将定义JobDetail, trigger的代码放到执行的main方法里:

 

Java代码   收藏代码
  1. package com.chanjet.chanapp;  
  2.   
  3. import org.quartz.CronScheduleBuilder;  
  4. import org.quartz.JobBuilder;  
  5. import org.quartz.JobDetail;  
  6. import org.quartz.Scheduler;  
  7. import org.quartz.SchedulerException;  
  8. import org.quartz.SchedulerFactory;  
  9. import org.quartz.Trigger;  
  10. import org.quartz.TriggerBuilder;  
  11. import org.quartz.impl.StdSchedulerFactory;  
  12.   
  13.   
  14. public class App   
  15. {  
  16.     public static void main( String[] args ) throws SchedulerException, InterruptedException  
  17.     {  
  18.         SchedulerFactory sf = new StdSchedulerFactory();  
  19.         Scheduler sched = sf.getScheduler();  
  20.           
  21.         JobDetail job = JobBuilder.newJob(SimpleJob.class).build();  
  22.           
  23.         Trigger trigger = TriggerBuilder  
  24.                 .newTrigger()  
  25.                 .withIdentity("testTrigger1""group1")  
  26.                 .withSchedule(CronScheduleBuilder.cronSchedule("0/4 * * * * ?"))  
  27.                 .build();  
  28.           
  29.         sched.scheduleJob(job, trigger);  
  30.         sched.start();  
  31.         Thread.sleep(90L * 1000L);  
  32.         sched.shutdown(true);  
  33.     }  
  34. }  
     我们定义了job,然后通过trigger每4秒钟启动一次job。这里的代码和前面的文章里讲到的示例一样,没有什么特殊的地方。

 

  稍微有点不一样的地方是我们在这里还要添加一个properties文件,我们放到resources的目录下面,properties文件名为quartz.properties:

 

Properties代码   收藏代码
  1. #============================================================================  
  2. # Configure Main Scheduler Properties    
  3. #============================================================================  
  4.   
  5. org.quartz.scheduler.instanceName: TestScheduler1  
  6. org.quartz.scheduler.instanceId: instance1  
  7.   
  8. org.quartz.scheduler.skipUpdateCheck: true  
  9.   
  10. #============================================================================  
  11. # Configure ThreadPool    
  12. #============================================================================  
  13.   
  14. org.quartz.threadPool.class: org.quartz.simpl.SimpleThreadPool  
  15. org.quartz.threadPool.threadCount: 5  
  16. org.quartz.threadPool.threadPriority: 5  
  17.   
  18. #============================================================================  
  19. # Configure JobStore    
  20. #============================================================================  
  21.   
  22. org.quartz.jobStore.misfireThreshold: 60000  
  23.   
  24. org.quartz.jobStore.class=org.quartz.impl.jdbcjobstore.JobStoreTX  
  25. org.quartz.jobStore.driverDelegateClass=org.quartz.impl.jdbcjobstore.StdJDBCDelegate  
  26. org.quartz.jobStore.useProperties=false  
  27. org.quartz.jobStore.dataSource=myDS  
  28. org.quartz.jobStore.tablePrefix=QRTZ_  
  29. org.quartz.jobStore.isClustered=true  
  30.   
  31. #============================================================================  
  32. # Other Example Delegates  
  33. #============================================================================  
  34. #org.quartz.jobStore.driverDelegateClass=org.quartz.impl.jdbcjobstore.DB2v6Delegate  
  35. #org.quartz.jobStore.driverDelegateClass=org.quartz.impl.jdbcjobstore.DB2v7Delegate  
  36. #org.quartz.jobStore.driverDelegateClass=org.quartz.impl.jdbcjobstore.DriverDelegate  
  37. #org.quartz.jobStore.driverDelegateClass=org.quartz.impl.jdbcjobstore.HSQLDBDelegate  
  38. #org.quartz.jobStore.driverDelegateClass=org.quartz.impl.jdbcjobstore.MSSQLDelegate  
  39. #org.quartz.jobStore.driverDelegateClass=org.quartz.impl.jdbcjobstore.PointbaseDelegate  
  40. #org.quartz.jobStore.driverDelegateClass=org.quartz.impl.jdbcjobstore.PostgreSQLDelegate  
  41. #org.quartz.jobStore.driverDelegateClass=org.quartz.impl.jdbcjobstore.StdJDBCDelegate  
  42. #org.quartz.jobStore.driverDelegateClass=org.quartz.impl.jdbcjobstore.WebLogicDelegate  
  43. #org.quartz.jobStore.driverDelegateClass=org.quartz.impl.jdbcjobstore.oracle.OracleDelegate  
  44. #org.quartz.jobStore.driverDelegateClass=org.quartz.impl.jdbcjobstore.oracle.WebLogicOracleDelegate  
  45.   
  46. #============================================================================  
  47. # Configure Datasources    
  48. #============================================================================  
  49.   
  50. org.quartz.dataSource.myDS.driver: com.mysql.jdbc.Driver  
  51. org.quartz.dataSource.myDS.URL: jdbc:mysql://localhost:3306/qrtz  
  52. org.quartz.dataSource.myDS.user: root  
  53. org.quartz.dataSource.myDS.password: pwd  
  54. org.quartz.dataSource.myDS.maxConnections: 5  
  55. org.quartz.dataSource.myDS.validationQuery: select 0  
  56.   
  57. #============================================================================  
  58. # Configure Plugins   
  59. #============================================================================  
  60.   
  61. #org.quartz.plugin.shutdownHook.class: org.quartz.plugins.management.ShutdownHookPlugin  
  62. #org.quartz.plugin.shutdownHook.cleanShutdown: true  
  63.   
  64.   
  65. #org.quartz.plugin.triggHistory.class: org.quartz.plugins.history.LoggingJobHistoryPlugin  
   这里的resources是我们创建的一个source folder,在执行的时候这个目录里的内容可以被jvm来装载。因为它是被定义在classpath中的。

 

  如果我们简单的执行程序,会看到如下的输出:

 

Java代码   收藏代码
  1. SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".  
  2. SLF4J: Defaulting to no-operation (NOP) logger implementation  
  3. SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details.  
  4. Dec 172014 6:31:10 AM com.mchange.v2.log.MLog <clinit>  
  5. INFO: MLog clients using java 1.4+ standard logging.  
  6. Dec 172014 6:31:10 AM com.mchange.v2.c3p0.C3P0Registry banner  
  7. INFO: Initializing c3p0-0.9.1.1 [built 15-March-2007 01:32:31; debug? true; trace: 10]  
  8. Dec 172014 6:31:10 AM com.mchange.v2.c3p0.impl.AbstractPoolBackedDataSource getPoolManager  
  9. INFO: Initializing c3p0 pool... com.mchange.v2.c3p0.ComboPooledDataSource [ acquireIncrement -> 3, acquireRetryAttempts -> 30, acquireRetryDelay -> 1000, autoCommitOnClose -> false, automaticTestTable -> null, breakAfterAcquireFailure -> false, checkoutTimeout -> 0, connectionCustomizerClassName -> null, connectionTesterClassName -> com.mchange.v2.c3p0.impl.DefaultConnectionTester, dataSourceName -> z8kfsx96ollhm9r8reo7|719f9c2e, debugUnreturnedConnectionStackTraces -> false, description -> null, driverClass -> com.mysql.jdbc.Driver, factoryClassLocation -> null, forceIgnoreUnresolvedTransactions -> false, identityToken -> z8kfsx96ollhm9r8reo7|719f9c2e, idleConnectionTestPeriod -> 50, initialPoolSize -> 3, jdbcUrl -> jdbc:mysql://localhost:3306/qrtz, lastAcquisitionFailureDefaultUser -> null, maxAdministrativeTaskTime -> 0, maxConnectionAge -> 0, maxIdleTime -> 0, maxIdleTimeExcessConnections -> 0, maxPoolSize -> 5, maxStatements -> 0, maxStatementsPerConnection -> 120, minPoolSize -> 1, numHelperThreads -> 3, numThreadsAwaitingCheckoutDefaultUser -> 0, preferredTestQuery -> select 0, properties -> {user=******, password=******}, propertyCycle -> 0, testConnectionOnCheckin -> true, testConnectionOnCheckout -> false, unreturnedConnectionTimeout -> 0, usesTraditionalReflectiveProxies -> false ]  
  10. Job executed...  
  11. Job executed...  
  12. Job executed...  
    这里的输出内容每4秒钟打印一次。按照前面的配置内容,我们去看数据库里的内容:

 

 

Sql代码   收藏代码
  1. mysql> select * from QRTZ_CRON_TRIGGERS;  
  2. +----------------+--------------+---------------+-----------------+---------------------+  
  3. | SCHED_NAME     | TRIGGER_NAME | TRIGGER_GROUP | CRON_EXPRESSION | TIME_ZONE_ID        |  
  4. +----------------+--------------+---------------+-----------------+---------------------+  
  5. | TestScheduler1 | testTrigger1 | group1        | 0/4 * * * * ?   | America/Los_Angeles |  
  6. +----------------+--------------+---------------+-----------------+---------------------+  
  7. 1 row in set (0.00 sec)  
   因为前面代码里定义了触发器trigger是crontrigger,这里就显示了trigger name和group。

 

 

Sql代码   收藏代码
  1. mysql> select * from QRTZ_SCHEDULER_STATE;  
  2. +----------------+---------------+-------------------+------------------+  
  3. | SCHED_NAME     | INSTANCE_NAME | LAST_CHECKIN_TIME | CHECKIN_INTERVAL |  
  4. +----------------+---------------+-------------------+------------------+  
  5. | TestScheduler1 | instance1     |     1418826761247 |             7500 |  
  6. +----------------+---------------+-------------------+------------------+  
  7. 1 row in set (0.00 sec)  
  配置文件里定义的内容instancename, instanceid在这里都有对应上了。

 

  为什么我们定义好之后只要把properties文件放到classpath就可以实现这个cluster的效果呢?其实原因很简单,quartz已经帮我们做了大部分的事情了。在默认的情况下quartz会去找classpath中默认名字为quartz.properties的文件,然后按照这里的配置来执行。如果我们的classpath里没有这个文件的话,它会去装载quartz jar包里的quartz.properties文件。在这个文件里,相当于它的默认配置,是没有使用持久化的存储,而是使用的ramstore。在实际应用的过程中,为了防止一个job被重复启动和并发的执行,有时候我们需要在job的定义实现上添加一些限制,如@PersistJobDataAfterExecution @DisallowConcurrentExecution。

  这样,一个最简单的quartz cluster示例就完成了。我们再来看看结合spring的情况下该怎么配。

 

spring quartz示例

    我们首先建一个maven工程SpringQuartzClusterSample,其pom.xml文件配置如下:

 

Xml代码   收藏代码
  1. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  2.   xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">  
  3.   <modelVersion>4.0.0</modelVersion>  
  4.   
  5.   <groupId>com.yunzero</groupId>  
  6.   <artifactId>SpringQuartzClusterSample</artifactId>  
  7.   <version>0.0.1-SNAPSHOT</version>  
  8.   <packaging>jar</packaging>  
  9.   
  10.   <name>SpringQuartzClusterSample</name>  
  11.   <url>http://maven.apache.org</url>  
  12.   
  13.   <properties>  
  14.     <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>  
  15.   </properties>  
  16.   
  17.   <dependencies>  
  18.         <dependency>  
  19.             <groupId>org.springframework</groupId>  
  20.             <artifactId>spring-context-support</artifactId>  
  21.             <version>4.0.4.RELEASE</version>  
  22.         </dependency>  
  23.   
  24.         <dependency>  
  25.             <groupId>org.springframework</groupId>  
  26.             <artifactId>spring-jdbc</artifactId>  
  27.             <version>4.0.4.RELEASE</version>  
  28.         </dependency>  
  29.   
  30.         <dependency>  
  31.             <groupId>org.quartz-scheduler</groupId>  
  32.             <artifactId>quartz</artifactId>  
  33.             <version>2.2.1</version>  
  34.         </dependency>  
  35.   
  36.         <!-- jdbc driver begin -->  
  37.         <dependency>  
  38.             <groupId>mysql</groupId>  
  39.             <artifactId>mysql-connector-java</artifactId>  
  40.             <version>5.1.21</version>  
  41.             <scope>runtime</scope>  
  42.         </dependency>  
  43.   
  44.         <dependency>  
  45.             <groupId>org.springframework</groupId>  
  46.             <artifactId>spring-test</artifactId>  
  47.             <version>4.0.4.RELEASE</version>  
  48.         </dependency>  
  49.   
  50.         <dependency>  
  51.             <groupId>junit</groupId>  
  52.             <artifactId>junit</artifactId>  
  53.             <version>4.11</version>  
  54.             <scope>test</scope>  
  55.         </dependency>  
  56.   </dependencies>  
  57. </project>  

     这里主要引用了spring的一些基本配置和运行时需要访问数据库的jdbc driver。

    然后我们定义一个实现的job:

 

Java代码   收藏代码
  1. package com.yunzero;  
  2.   
  3. import org.quartz.DisallowConcurrentExecution;  
  4. import org.quartz.JobExecutionContext;  
  5. import org.quartz.JobExecutionException;  
  6. import org.quartz.PersistJobDataAfterExecution;  
  7. import org.springframework.scheduling.quartz.QuartzJobBean;  
  8.   
  9. @PersistJobDataAfterExecution  
  10. @DisallowConcurrentExecution  
  11. public class SimpleJob extends QuartzJobBean {  
  12.   
  13.     @Override  
  14.     protected void executeInternal(JobExecutionContext arg0)  
  15.             throws JobExecutionException {  
  16.         System.out.println("Job started..");  
  17.     }  
  18.   
  19. }  

     也是一个简单的打印输出。

    剩下的就是在配置文件里配置好jobdetails, triggers等这些:

 

Xml代码   收藏代码
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <beans xmlns="http://www.springframework.org/schema/beans"  
  3.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  4.     xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">  
  5.   
  6.     <bean id="firstJobDetail" class="org.springframework.scheduling.quartz.JobDetailFactoryBean">  
  7.         <property name="jobClass" value="com.yunzero.SimpleJob"/>  
  8.         <property name="durability" value="true" />     
  9.         <property name="requestsRecovery" value="true" />  
  10.     </bean>  
  11.       
  12.     <bean id="firstTrigger" class="org.springframework.scheduling.quartz.CronTriggerFactoryBean">  
  13.         <property name="jobDetail" ref="firstJobDetail" />  
  14.         <property name="cronExpression" value="0/5 * * ? * * *" />  
  15.     </bean>  
  16.       
  17.     <bean name="quartzScheduler"  
  18.         class="org.springframework.scheduling.quartz.SchedulerFactoryBean">  
  19.         <property name="configLocation" value="classpath:quartz.properties" />  
  20.         <property name="jobDetails">  
  21.             <list>  
  22.                 <ref bean="firstJobDetail"/>  
  23.             </list>  
  24.         </property>  
  25.         <property name="triggers">  
  26.             <list>  
  27.                 <ref bean="firstTrigger"/>  
  28.             </list>  
  29.         </property>  
  30.     </bean>     
  31.   
  32. </beans>  

   我们这里和普通的配置差不多,这里唯一有差异的两个地方是在jobDetails里面设置它的durability属性为true,另外还在quartzScheduler里配置了configLocation,它引用了quartz.properties文件。在quartz.properties里我们配置了计划任务集群的详细信息:

 

Java代码   收藏代码
  1. #============================================================================  
  2. # Configure Main Scheduler Properties    
  3. #============================================================================  
  4.   
  5. org.quartz.scheduler.instanceName: TestScheduler1  
  6. org.quartz.scheduler.instanceId: instance1  
  7.   
  8. org.quartz.scheduler.skipUpdateCheck: true  
  9.   
  10. #============================================================================  
  11. # Configure ThreadPool    
  12. #============================================================================  
  13.   
  14. org.quartz.threadPool.class: org.quartz.simpl.SimpleThreadPool  
  15. org.quartz.threadPool.threadCount: 5  
  16. org.quartz.threadPool.threadPriority: 5  
  17.   
  18. #============================================================================  
  19. # Configure JobStore    
  20. #============================================================================  
  21.   
  22. org.quartz.jobStore.misfireThreshold: 60000  
  23.   
  24. org.quartz.jobStore.class=org.quartz.impl.jdbcjobstore.JobStoreTX  
  25. org.quartz.jobStore.driverDelegateClass=org.quartz.impl.jdbcjobstore.StdJDBCDelegate  
  26. org.quartz.jobStore.useProperties=false  
  27. org.quartz.jobStore.dataSource=myDS  
  28. org.quartz.jobStore.tablePrefix=QRTZ_  
  29. org.quartz.jobStore.isClustered=true  
  30.   
  31. #============================================================================  
  32. # Other Example Delegates  
  33. #============================================================================  
  34. #org.quartz.jobStore.driverDelegateClass=org.quartz.impl.jdbcjobstore.DB2v6Delegate  
  35. #org.quartz.jobStore.driverDelegateClass=org.quartz.impl.jdbcjobstore.DB2v7Delegate  
  36. #org.quartz.jobStore.driverDelegateClass=org.quartz.impl.jdbcjobstore.DriverDelegate  
  37. #org.quartz.jobStore.driverDelegateClass=org.quartz.impl.jdbcjobstore.HSQLDBDelegate  
  38. #org.quartz.jobStore.driverDelegateClass=org.quartz.impl.jdbcjobstore.MSSQLDelegate  
  39. #org.quartz.jobStore.driverDelegateClass=org.quartz.impl.jdbcjobstore.PointbaseDelegate  
  40. #org.quartz.jobStore.driverDelegateClass=org.quartz.impl.jdbcjobstore.PostgreSQLDelegate  
  41. #org.quartz.jobStore.driverDelegateClass=org.quartz.impl.jdbcjobstore.StdJDBCDelegate  
  42. #org.quartz.jobStore.driverDelegateClass=org.quartz.impl.jdbcjobstore.WebLogicDelegate  
  43. #org.quartz.jobStore.driverDelegateClass=org.quartz.impl.jdbcjobstore.oracle.OracleDelegate  
  44. #org.quartz.jobStore.driverDelegateClass=org.quartz.impl.jdbcjobstore.oracle.WebLogicOracleDelegate  
  45.   
  46. #============================================================================  
  47. # Configure Datasources    
  48. #============================================================================  
  49.   
  50. org.quartz.dataSource.myDS.driver: com.mysql.jdbc.Driver  
  51. org.quartz.dataSource.myDS.URL: jdbc:mysql://localhost:3306/qrtz  
  52. org.quartz.dataSource.myDS.user: root  
  53. org.quartz.dataSource.myDS.password: test  
  54. org.quartz.dataSource.myDS.maxConnections: 5  
  55. org.quartz.dataSource.myDS.validationQuery: select 0  
  56.   
  57. #============================================================================  
  58. # Configure Plugins   
  59. #============================================================================  
  60.   
  61. #org.quartz.plugin.shutdownHook.class: org.quartz.plugins.management.ShutdownHookPlugin  
  62. #org.quartz.plugin.shutdownHook.cleanShutdown: true  
  63.   
  64.   
  65. #org.quartz.plugin.triggHistory.class: org.quartz.plugins.history.LoggingJobHistoryPlugin  

    这部分和前面的配置基本上没有差异。然后剩下的就是启动spring container的部分:

 

Java代码   收藏代码
  1. package com.yunzero;  
  2.   
  3. import org.springframework.context.ApplicationContext;  
  4. import org.springframework.context.support.ClassPathXmlApplicationContext;  
  5.   
  6.   
  7. public class App   
  8. {  
  9.     public static void main( String[] args )  
  10.     {  
  11.         ApplicationContext springContext =   
  12.                 new ClassPathXmlApplicationContext("applicationContext.xml");  
  13.     }  
  14. }  

     如果我们运行程序的话,会得到如下的输出:

 

Java代码   收藏代码
  1. Dec 222014 10:41:04 PM org.springframework.context.support.ClassPathXmlApplicationContext prepareRefresh  
  2. INFO: Refreshing org.springframework.context.support.ClassPathXmlApplicationContext@3344c133: startup date [Mon Dec 22 22:41:04 CST 2014]; root of context hierarchy  
  3. Dec 222014 10:41:04 PM org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions  
  4. INFO: Loading XML bean definitions from class path resource [applicationContext.xml]  
  5. SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".  
  6. SLF4J: Defaulting to no-operation (NOP) logger implementation  
  7. SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details.  
  8. Dec 222014 10:41:04 PM org.springframework.scheduling.quartz.SchedulerFactoryBean initSchedulerFactory  
  9. INFO: Loading Quartz config from [class path resource [quartz.properties]]  
  10. Dec 222014 10:41:04 PM com.mchange.v2.log.MLog <clinit>  
  11. INFO: MLog clients using java 1.4+ standard logging.  
  12. Dec 222014 10:41:04 PM com.mchange.v2.c3p0.C3P0Registry banner  
  13. INFO: Initializing c3p0-0.9.1.1 [built 15-March-2007 01:32:31; debug? true; trace: 10]  
  14. Dec 222014 10:41:04 PM com.mchange.v2.c3p0.impl.AbstractPoolBackedDataSource getPoolManager  
  15. INFO: Initializing c3p0 pool... com.mchange.v2.c3p0.ComboPooledDataSource [ acquireIncrement -> 3, acquireRetryAttempts -> 30, acquireRetryDelay -> 1000, autoCommitOnClose -> false, automaticTestTable -> null, breakAfterAcquireFailure -> false, checkoutTimeout -> 0, connectionCustomizerClassName -> null, connectionTesterClassName -> com.mchange.v2.c3p0.impl.DefaultConnectionTester, dataSourceName -> z8kfsx96vr5hgx1nwo0d3|109999f1, debugUnreturnedConnectionStackTraces -> false, description -> null, driverClass -> com.mysql.jdbc.Driver, factoryClassLocation -> null, forceIgnoreUnresolvedTransactions -> false, identityToken -> z8kfsx96vr5hgx1nwo0d3|109999f1, idleConnectionTestPeriod -> 50, initialPoolSize -> 3, jdbcUrl -> jdbc:mysql://localhost:3306/qrtz, lastAcquisitionFailureDefaultUser -> null, maxAdministrativeTaskTime -> 0, maxConnectionAge -> 0, maxIdleTime -> 0, maxIdleTimeExcessConnections -> 0, maxPoolSize -> 5, maxStatements -> 0, maxStatementsPerConnection -> 120, minPoolSize -> 1, numHelperThreads -> 3, numThreadsAwaitingCheckoutDefaultUser -> 0, preferredTestQuery -> select 0, properties -> {user=******, password=******}, propertyCycle -> 0, testConnectionOnCheckin -> true, testConnectionOnCheckout -> false, unreturnedConnectionTimeout -> 0, usesTraditionalReflectiveProxies -> false ]  
  16. Dec 222014 10:41:05 PM org.springframework.context.support.DefaultLifecycleProcessor start  
  17. INFO: Starting beans in phase 2147483647  
  18. Dec 222014 10:41:05 PM org.springframework.scheduling.quartz.SchedulerFactoryBean startScheduler  
  19. INFO: Starting Quartz Scheduler now  
  20. Job started..  
  21. Job started..  
  22. Job started..  
  23. Job started..  
  24. Job started..  
  25. Job started..  

   因为配置的任务是每5秒钟执行一次,所以每次会在屏幕打印输出内容。如果我们去检查数据库的话,也会发现和上面示例类似的内容。

    这样,一个spring quartz的cluster示例就配置完成了。具体的细节可以参照后面的附件。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值