失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > Spring+quartz集群配置 Spring定时任务集群 quartz定时任务集群

Spring+quartz集群配置 Spring定时任务集群 quartz定时任务集群

时间:2024-01-11 11:20:00

相关推荐

Spring+quartz集群配置 Spring定时任务集群 quartz定时任务集群

Spring+quartz集群配置,Spring定时任务集群,quartz定时任务集群

>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>

蕃薯耀 7月7日 09:06:09 星期四

/

一、问题描述

Spring自带的Task虽然能很好使用定时任务,只需要做些简单的配置就可以了。不过如果部署在多台服务器上的时候,这样定时任务会在每台服务器都会执行,造成重复执行。

二、解决方案

Spring+quartz 集群可以解决多服务器部署定时器重复执行的问题。

1、下载quartz的Jar包或者在Maven项目加入quartz的依赖包

不再细说,详情可参考:

Spring4整合quartz2.2定时任务:/blog/2309223

2、建立quartz表

quartz是通过表来实现多服务器定时任务集群的,表的详细信息在压缩包:quartz-2.2.3-distribution.tar.gz,

路径为:quartz-2.2.3-distribution\quartz-2.2.3\docs\dbTables

这里有很多表的SQL可执行语句,直接复制执行即可。

其中附件有quartz-2.2.3-distribution.tar.gz,是-07-07最新的。

本人使用的是Mysql,执行的是tables_mysql_innodb.sql,另外一个tables_mysql.sql没执行,看都没有看,哈哈。

注:最好先建完表,再执行后面的索引,不然会有警告。

里面的表详细本人也不了解,就不说了,百度或Google吧。

3、新增一个Bean文件(spring-quartz.xml),如下:

<?xml version="1.0" encoding="UTF-8"?><beans xmlns="/schema/beans"xmlns:xsi="/2001/XMLSchema-instance"xsi:schemaLocation="/schema/beans /schema/beans/spring-beans.xsd"><!-- 配置任务bean类 --><bean id="quartzTask" class="com.lqy.spring.task.QuartzTask"></bean><!-- 配置方法映射工厂类 --><!-- MethodInvokingJobDetailFactoryBean不支持序列化 --><!-- <bean id="jobDetail" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean"><property name="targetObject" ref="quartzTask"></property><property name="targetMethod" value="startTask"></property><property name="concurrent" value="false"></property>concurrent : false表示等上一个任务执行完后再开启新的任务</bean> --><!-- 配置方法映射工厂类 --><bean id="jobDetail" class="org.springframework.scheduling.quartz.JobDetailFactoryBean"><property name="jobClass" value="com.lqy.spring.task.QuartzTaskExtends"></property><property name="durability" value="true"></property><property name="requestsRecovery" value="true" /> </bean><!-- 配置任务高度的的时间/周期 --><bean id="jobTrigger" class="org.springframework.scheduling.quartz.CronTriggerFactoryBean"><property name="jobDetail" ref="jobDetail"></property><property name="cronExpression" value="0 */1 * * * ?"></property><!-- <property name="startDelay" value="3000"></property> --></bean><bean id="schedulerFactoryBean" class="org.springframework.scheduling.quartz.SchedulerFactoryBean"><property name="dataSource" ref="dataSource"></property> <!--可选,QuartzScheduler 启动时更新己存在的Job,这样就不用每次修改targetObject后删除qrtz_job_details表对应记录了 --> <property name="overwriteExistingJobs" value="true" /> <!--必须的,QuartzScheduler 延时启动,应用启动完后 QuartzScheduler 再启动 --> <property name="startupDelay" value="30" /> <!-- 设置自动启动 --> <property name="autoStartup" value="true" /><property name="applicationContextSchedulerContextKey" value="applicationContextKey" /> <property name="configLocation" value="classpath:spring-quartz.properties" /> <property name="triggers"><list><ref bean="jobTrigger"/></list></property></bean></beans>

spring-quartz.xml文件里面主要配置的是定时任务

其中和一般Spring整合quartz定时任务不同的是:

(1)使用数据源:

在Bean id="schedulerFactoryBean"中使用了数据源:

<property name="dataSource" ref="dataSource"></property>

数据源dataSource是在Spring.xml文件配置的。

(2)jobDetail使用的是org.springframework.scheduling.quartz.JobDetailFactoryBean

由于集群需要把定时任务的信息写入表,需要序列化吧,但MethodInvokingJobDetailFactoryBean 不能序列化,会报错。

(3)增加spring-quartz.properties文件

#============================================================== #Configure Main Scheduler Properties #============================================================== org.quartz.scheduler.instanceName = defaultSchedulerorg.quartz.scheduler.instanceId = AUTO#============================================================== #Configure JobStore #============================================================== org.quartz.jobStore.class = org.quartz.impl.jdbcjobstore.JobStoreTXorg.quartz.jobStore.driverDelegateClass = org.quartz.impl.jdbcjobstore.StdJDBCDelegateorg.quartz.jobStore.tablePrefix = QRTZ_org.quartz.jobStore.isClustered = trueorg.quartz.jobStore.clusterCheckinInterval = 20000 org.quartz.jobStore.dataSource = myDSorg.quartz.jobStore.maxMisfiresToHandleAtATime = 1org.quartz.jobStore.misfireThreshold = 120000org.quartz.jobStore.txIsolationLevelSerializable = true#============================================================== #Configure ThreadPool #============================================================== org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPoolorg.quartz.threadPool.threadCount = 10org.quartz.threadPool.threadPriority = 5org.quartz.threadPool.threadsInheritContextClassLoaderOfInitializingThread = true#==============================================================#Skip Check Update#update:true#not update:false#==============================================================org.quartz.scheduler.skipUpdateCheck = true #============================================================================ # Configure Plugins #============================================================================org.quartz.plugin.triggHistory.class = org.quartz.plugins.history.LoggingJobHistoryPlugin org.quartz.plugin.shutdownhook.class = org.quartz.plugins.management.ShutdownHookPluginorg.quartz.plugin.shutdownhook.cleanShutdown = true

这个配置文件也是Quartz的配置文件,本人也不了解,只是从网上搜索来的。本来是有数据库的连接配置的,但由于spring配置文件已经有数据源,我就删除掉了。

4、把上面的spring-quartz.xml 引入到spring.xml文件中:

<import resource="spring-quartz.xml"/>

或者在web.xml文件加上,这种方法没有尝试,但应该是可以的:

<context-param><param-name>contextConfigLocation</param-name><param-value>classpath:spring.xml,classpath:spring-quartz.xml</param-value></context-param>

5、把项目部署到集群环境中

其实就是把项目部署到2个Tomcat中,这样能看到定时任务是否重复执行。

Tomcat+Nginx集群详情见:/blog/2309601

6、启动所有Tomcat,看结果,如下:

由图可见:定时器是每分钟的0秒执行一次

在2个Tomcat中,分别是一个tomcat执行一次,另一个tomcat执行一次,没有重复执行,这样就达到了定时器的集群效果,成功。

参考资料:

spring定时任务:/blog/2267243

Spring4整合quartz2.2定时任务:/blog/2309223

Tomcat+Nginx集群:/blog/2309601

>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>

蕃薯耀 7月7日 09:06:09 星期四

/

如果觉得《Spring+quartz集群配置 Spring定时任务集群 quartz定时任务集群》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。