- 浏览: 641592 次
- 性别:
- 来自: 杭州
文章分类
最新评论
-
liuche20083736:
非常好
从问题看本质: 研究TCP close_wait的内幕 -
xiaopohai85707:
优化算法与原来需求不符
过滤字符的性能调优?挤一挤还是有的 -
kmy_白衣:
生成的area图有时候 标签的数值和图标上看上去的数值不一致。 ...
OpenFlashChart2之恶心文档 -
tom&jerry:
大神,请教一个问题,按名称排序为何无效,用的2.4.3 XPA ...
深入浅出jackrabbit之十三 查询之AST和QT -
jd2bs:
改成精确匹配可以了< filter-mapping &g ...
细谈Ehcache页面缓存的使用
之前看到很多关于quartz的讨论,尤其是关于quartz和集群应用的讨论是非常的激烈,很多人都共享了自己的想法,很多基本上比较统一的观点是重新启动一个job server,用来跑job,然后把这个job server独立在web container之外启动。然后各节点如果需要启动任务那么就通过db或jms来通知job server。这个方法是robbin大哥提出的,原贴见http://www.iteye.com/topic/40970,第8楼。用这种方法比较好的处理了quartz和应用集群问题。
为了更好的说明这个问题,我画了一张图:
见图qu2
首先请大家原谅,这个图是我用visio画的,画的不咋滴(上次收到pd的警告信之后不敢再用pd了),大概就是这个样子吧,如果理解有误请大家指出来啊。这种情况下jobserver也可以看作是一个node,如果定时任务很多的话就有问题了,因为所有的任务都会在这个节点上运行。
第二种方案
在上面的基础上,我想到,能不能通过轻量级远程调用和quartz结合起来,也是把任务定时跑到一个jobserver上,但是正真跑任务还是在web节点上,那么如何实现呢,我也来详细讲解一下自己的想法。
1, 独立出一个job server,这个server上跑一个spring+quartz的应用,这个应用专门用来启动任务。
2, 在jobserver上加上hessain,得到业务接口,这样jobserver就可以调用web container中的业务操作,也就是正真执行任务的还是在cluster中的tomcat。
3, 在jobserver上配置cluster上各节点的地址,即各tomcat的hessian。他们的业务接口都是一样的,只不过地址是不一样的。
4, 在jobserver启动定时任务之后,轮流调用各地址上的业务操作(类似apache分发tomcat一样),这样可以让不同的定时任务在不同的节点上运行,减低了一台某个node的压力(我觉得这个优点是一个比较重要的优点,尤其是定时任务比较重的情况下)。
让我们来看看图示:
见图qu1
我觉得这种方式对jobserver来说就比较简单了,它只需要考虑调用谁谁谁,不需要把node上的应用部署到JobServer上去,但是有优点肯定就有缺点(用易中天的话说:喜欢的人越多,反对的声浪也越高),我们再来看看这种方式的缺点:
1 即使是用了hessain也可以象上面那种方式jobserver是一个单独的虚拟机实例,不在web container中。当然我们也可以用RMI来代替,而且RMI的速度比hessian快得多,但是显然带来的是开发上更多的复杂性,RMI环境的配置非常麻烦,而且在网络端口方面也存在一些问题,如防火墙的问题等。
2 网络延迟问题,如果是时间要求比较精准的任务用这种方案就不合适了,因为hessain调用是有网络延迟的时间的,数量级从十到百不等,单位十毫秒。尤其是第一次调用,可能需要1秒钟,如果在同一台机器上第一次调用大概是300-600毫秒。
3 需要再做一个额外的web应用,就是做一个基于web的jobserver(不过这一条也不一定是缺点)
这两种方法事实上都没有把quart集群起来,虽然应用是集群了,但是jobserver还是只有一个。第一种方案只能在jobserver中执行定时操作,第二种方法还是在集群的各节点中执行定时操作。在这两种情况下,只要jobserver挂了,整个定时的任务就挂了。
或者我们也可以把这些单独的jobserver集群起来,比如在第一种情况下再部署一个jobserver,通过数据库中的表的记录的锁定与否来判断这条任务是否在执行,这种情况下需要两个jobserver的时间一定要保持一致,因为如果有一个时间差,定时任务就有可能被执行两遍了。而且同一个应用就需要被部署多次,保存部署到jobserver上,如果在第二种情况下做集群,那么没有业务操作的jobserver集群起来应该是非常轻松的,但是还是有同样的问题,就是时间差不能太大,否则应用又会被调用多次。而且这两个方案的集群都需要数据库的支持(不过没有数据库还真不知道如何做到定时操作的集群了),这种方案要实现起来就需要另写文章仔细叙述了。
第三种情况:
quartz本身事实上也是支持集群的。在这种方案下,cluster上的每一个node都在跑quartz,然后也是通过数据中记录的状态来判断这个操作是否正在执行,这就要求cluster上所有的node的时间应该是一样的。而且每一个node都跑应用就意味着每一个node都需要有自己的线程池来跑quartz(俺反而觉得这样做比较累赘)。
见图qu3
这种方式也有一个很大的优点,就是不同的node可能会执行的不同的定时任务,这个要看服务器的时间设定了,可能node1执行一个任务,此时node2会执行另一个任务,这样做会比较好的做到负载均衡,而且也能比较好的做到容错,一个node挂了,不会
影响到其他node上的定时任务。每个node上的quartz定期的向数据库里登记它们的时
间,如果某个实例在一定的时间内没有登记,就表示这个实例挂了 ,其它的实例就会重新获取这个挂了的实例所执行的任务。
总结一下:
从上面的描述看来,3种方法都各有优点和缺点。我觉得不同的情况下应该选择自己项目最合适的方案。以上只不过是我自己天马行空想出来了,估计有些地方有问题,欢迎大家探讨一下这个问题。
让你一提醒我才注意到,其实我的图画的不严谨,第3个图中使用tomcat不是必需的,我画的是一种具体情况,也就是在tomcat的web应用中quartz集群的情况,我的图已经是具体到某一个具体场景了。事实上比较highlevel的图应该是这样的。
谢谢指正
你的这句话很容易让人产生误会,使用rmi的cluster server让人以为做cluster一定需要用rmi,其实不一定需要。
你上面贴出来的那个配置我当然知道啊,而且它的相关地址我在第8楼就贴出来了
http://wiki.opensymphony.com/display/QRTZ1/ConfigJDBCJobStoreClustering,
其实我说的第3种方案指得就是这一种。这种方式怎么能叫jvm级别的集群呢。这个是通过db来保证任务的执行的,所以当你说到
我所说的不是这几种,因为不会用到tomcat cluster,而是jvm cluster,也是quartz自己提供的
我就以为这个是另外一种集群方式。
到现在我终于明白你说得集群就是我文中提到的第3种集群
-0-那就是你的第3个图画错了,怎么也不是tomcat cluster
你的这句话很容易让人产生误会,使用rmi的cluster server让人以为做cluster一定需要用rmi,其实不一定需要。
你上面贴出来的那个配置我当然知道啊,而且它的相关地址我在第8楼就贴出来了
http://wiki.opensymphony.com/display/QRTZ1/ConfigJDBCJobStoreClustering,
其实我说的第3种方案指得就是这一种。这种方式怎么能叫jvm级别的集群呢。这个是通过db来保证任务的执行的,所以当你说到
我所说的不是这几种,因为不会用到tomcat cluster,而是jvm cluster,也是quartz自己提供的
我就以为这个是另外一种集群方式,所以我就觉得自己对quartz的经验不够用了,居然还有基于rmi的quartz集群。
到现在我终于明白你说得集群就是我文中提到的第3种集群
-0-我所有的回帖中都沒說rmi和集群有什麽關係!我都說了我只發現只有通過rmi接口來操作在jvm server上運行的job的
之前由于我对quartz的经验不够,所以说出了表示怀疑的话。我很想详细的学习一下你的做法,你能否把你的做法仔细阐述一下呢。
通过jvm的custer来做的话,那么如何通知其他node哪个job已经被执行或者是没有执行,时间同步问题你又是如何解决的呢。
而且你说通过一个web应用来调用rmi对jobserver进行任务的添加,但是这个不是rmi在jvm的cluster中的主要用途吧?多个节点上的quartz需要进行通信,我想你是不是通过rmi来进行通信的呢
1.如何通知其他node哪个job已经被执行或者是没有执行,多个节点上的quartz需要进行通信
這個是quartz cluster自己實現的,文檔代碼比較長,我建議你先看一下他的文檔 "quartz job scheduling framework"。另外,cluster必須是使用db的,所以對任務的操作基本上是基於他的JobStore的。
2.而且你说通过一个web应用来调用rmi对jobserver进行任务的添加,但是这个不是rmi在jvm的cluster中的主要用途吧?
因爲目前我只發現他提供的rmi的接口可以對jvm server上的job作操作。
3.时间同步问题
quartz提供了一個的解決方案(http://tf.nist.gov/service/its.htm),我還沒有試過。
另外可以做硬件server的cluster。
我帮公司做了一个jvm cluster的,然后有一个web端通过rmi来新增job,
之前由于我对quartz的经验不够,所以说出了表示怀疑的话。我很想详细的学习一下你的做法,你能否把你的做法仔细阐述一下呢。
通过jvm的custer来做的话,那么如何通知其他node哪个job已经被执行或者是没有执行,时间同步问题你又是如何解决的呢。
而且你说通过一个web应用来调用rmi对jobserver进行任务的添加,但是这个不是rmi在jvm的cluster中的主要用途吧?多个节点上的quartz需要进行通信,我想你是不是通过rmi来进行通信的呢
刚才google了一下,发现网上并没有quartz在jvm级别做集群得描述,
http://wiki.opensymphony.com/display/QRTZ1/ConfigRMI,这个页面是关于rmi配置的,在这里我丝毫没有看到cluster这个字眼。
http://wiki.opensymphony.com/display/QRTZ1/ConfigJDBCJobStoreClustering,这个页面是我所描述得关于jdbcjobstore的描述。
而且你说到
从上面那个连接来看,这个datasource的作用其实就是支持我说的第三种方案。
而且在用jdbcjobstore做集群的时候就是需要配置:
quartzServerC1.properties:
org.quartz.scheduler.instanceName = QuartzServer
org.quartz.scheduler.instanceId = ONE
quartzServerC2.properties:
org.quartz.scheduler.instanceName = QuartzServer
org.quartz.scheduler.instanceId = TWO
还有datasource,这些配置不是用到什么“jvm级别”的集群上的,却是在使用jdbcjobstore做集群时所需的配置
你说了用rmi做jvm级别的集群我认为并不存在,除非你拿出证据来,或者证明你确实这样做过
你说的对,不过我是想如果可以的话可以做一个web端来监控quartz执行的状态,当然如果不需要这样做的话可以不用web容器。
我帮公司做了一个jvm cluster的,然后有一个web端通过rmi来新增job,
第一种方案在不集群的情况下不能负载均衡啊,我还是认为这种三种方案应该是有不同的使用场景,应该试情况而定
刚才google了一下,发现网上并没有quartz在jvm级别做集群得描述,
http://wiki.opensymphony.com/display/QRTZ1/ConfigRMI,这个页面是关于rmi配置的,在这里我丝毫没有看到cluster这个字眼。
http://wiki.opensymphony.com/display/QRTZ1/ConfigJDBCJobStoreClustering,这个页面是我所描述得关于jdbcjobstore的描述。
而且你说到
从上面那个连接来看,这个datasource的作用其实就是支持我说的第三种方案。
而且在用jdbcjobstore做集群的时候就是需要配置:
quartzServerC1.properties:
org.quartz.scheduler.instanceName = QuartzServer
org.quartz.scheduler.instanceId = ONE
quartzServerC2.properties:
org.quartz.scheduler.instanceName = QuartzServer
org.quartz.scheduler.instanceId = TWO
还有datasource,这些配置不是用到什么“jvm级别”的集群上的,却是在使用jdbcjobstore做集群时所需的配置
你说了用rmi做jvm级别的集群我认为并不存在,除非你拿出证据来,或者证明你确实这样做过
你说的对,不过我是想如果可以的话可以做一个web端来监控quartz执行的状态,当然如果不需要这样做的话可以不用web容器。
首先说明一下老贴不代表没有价值
虽然第3种情况既能做到负载均衡,也能做到容错,但是也是有点代价的。
我觉得第3种方案有如下的缺点:
quartz需要使用jdbc-jobstore,quartz本身的性能减低。
所有节点所在机器的时间相差必须在一秒之内。
如果还有其他没有集群的quartz的话不能用这个jdbc-jobstore,不然可能会出问题。
所有的节点(web应用)都需要跑quartz实例,那么每个节点上都需要额外的线程池,而且参照前人的经验,如果考虑不周,
可能会导致servlet资源不能释放的问题。
还有一个是实现起来比较繁琐。
我所说的不是这几种,因为不会用到tomcat cluster,而是jvm cluster,也是quartz自己提供的,所以不存在servlet资源不能释放的问题。
既它的文档上说的
quartzServerC1.properties:
org.quartz.scheduler.instanceName = QuartzServer
org.quartz.scheduler.instanceId = ONE
quartzServerC2.properties:
org.quartz.scheduler.instanceName = QuartzServer
org.quartz.scheduler.instanceId = TWO
这样就是他的cluster最简单的配置,当然你还需要配置她的Datasource,如果你需要及时提交job,那你还需要加上
org.quartz.scheduler.rmi.export = true
org.quartz.scheduler.rmi.registryHost = localhost
org.quartz.scheduler.rmi.registryPort = 1198
org.quartz.scheduler.rmi.serverPort = 0
org.quartz.scheduler.rmi.createRegistry = true
之类的,然后自己写个web应用或其他的来call他的rmi接口
首先说明一下老贴不代表没有价值
虽然第3种情况既能做到负载均衡,也能做到容错,但是也是有点代价的。
我觉得第3种方案有如下的缺点:
quartz需要使用jdbc-jobstore,quartz本身的性能减低。
所有节点所在机器的时间相差必须在一秒之内。
如果还有其他没有集群的quartz的话不能用这个jdbc-jobstore,不然可能会出问题。
所有的节点(web应用)都需要跑quartz实例,那么每个节点上都需要额外的线程池,而且参照前人的经验,如果考虑不周,
可能会导致servlet资源不能释放的问题。
还有一个是实现起来比较繁琐。
我到不觉得我想太多了,而且第一种情况也不是我想出来的。
你说的情况就是文中所提的第3种情况,第3种情况有自己固有的缺点啊。
见正文,你的观点好像是不管什么情况,第3种方式一定是最合适的?
为了更好的说明这个问题,我画了一张图:
见图qu2
首先请大家原谅,这个图是我用visio画的,画的不咋滴(上次收到pd的警告信之后不敢再用pd了),大概就是这个样子吧,如果理解有误请大家指出来啊。这种情况下jobserver也可以看作是一个node,如果定时任务很多的话就有问题了,因为所有的任务都会在这个节点上运行。
第二种方案
在上面的基础上,我想到,能不能通过轻量级远程调用和quartz结合起来,也是把任务定时跑到一个jobserver上,但是正真跑任务还是在web节点上,那么如何实现呢,我也来详细讲解一下自己的想法。
1, 独立出一个job server,这个server上跑一个spring+quartz的应用,这个应用专门用来启动任务。
2, 在jobserver上加上hessain,得到业务接口,这样jobserver就可以调用web container中的业务操作,也就是正真执行任务的还是在cluster中的tomcat。
3, 在jobserver上配置cluster上各节点的地址,即各tomcat的hessian。他们的业务接口都是一样的,只不过地址是不一样的。
4, 在jobserver启动定时任务之后,轮流调用各地址上的业务操作(类似apache分发tomcat一样),这样可以让不同的定时任务在不同的节点上运行,减低了一台某个node的压力(我觉得这个优点是一个比较重要的优点,尤其是定时任务比较重的情况下)。
让我们来看看图示:
见图qu1
我觉得这种方式对jobserver来说就比较简单了,它只需要考虑调用谁谁谁,不需要把node上的应用部署到JobServer上去,但是有优点肯定就有缺点(用易中天的话说:喜欢的人越多,反对的声浪也越高),我们再来看看这种方式的缺点:
1 即使是用了hessain也可以象上面那种方式jobserver是一个单独的虚拟机实例,不在web container中。当然我们也可以用RMI来代替,而且RMI的速度比hessian快得多,但是显然带来的是开发上更多的复杂性,RMI环境的配置非常麻烦,而且在网络端口方面也存在一些问题,如防火墙的问题等。
2 网络延迟问题,如果是时间要求比较精准的任务用这种方案就不合适了,因为hessain调用是有网络延迟的时间的,数量级从十到百不等,单位十毫秒。尤其是第一次调用,可能需要1秒钟,如果在同一台机器上第一次调用大概是300-600毫秒。
3 需要再做一个额外的web应用,就是做一个基于web的jobserver(不过这一条也不一定是缺点)
这两种方法事实上都没有把quart集群起来,虽然应用是集群了,但是jobserver还是只有一个。第一种方案只能在jobserver中执行定时操作,第二种方法还是在集群的各节点中执行定时操作。在这两种情况下,只要jobserver挂了,整个定时的任务就挂了。
或者我们也可以把这些单独的jobserver集群起来,比如在第一种情况下再部署一个jobserver,通过数据库中的表的记录的锁定与否来判断这条任务是否在执行,这种情况下需要两个jobserver的时间一定要保持一致,因为如果有一个时间差,定时任务就有可能被执行两遍了。而且同一个应用就需要被部署多次,保存部署到jobserver上,如果在第二种情况下做集群,那么没有业务操作的jobserver集群起来应该是非常轻松的,但是还是有同样的问题,就是时间差不能太大,否则应用又会被调用多次。而且这两个方案的集群都需要数据库的支持(不过没有数据库还真不知道如何做到定时操作的集群了),这种方案要实现起来就需要另写文章仔细叙述了。
第三种情况:
quartz本身事实上也是支持集群的。在这种方案下,cluster上的每一个node都在跑quartz,然后也是通过数据中记录的状态来判断这个操作是否正在执行,这就要求cluster上所有的node的时间应该是一样的。而且每一个node都跑应用就意味着每一个node都需要有自己的线程池来跑quartz(俺反而觉得这样做比较累赘)。
见图qu3
这种方式也有一个很大的优点,就是不同的node可能会执行的不同的定时任务,这个要看服务器的时间设定了,可能node1执行一个任务,此时node2会执行另一个任务,这样做会比较好的做到负载均衡,而且也能比较好的做到容错,一个node挂了,不会
影响到其他node上的定时任务。每个node上的quartz定期的向数据库里登记它们的时
间,如果某个实例在一定的时间内没有登记,就表示这个实例挂了 ,其它的实例就会重新获取这个挂了的实例所执行的任务。
总结一下:
从上面的描述看来,3种方法都各有优点和缺点。我觉得不同的情况下应该选择自己项目最合适的方案。以上只不过是我自己天马行空想出来了,估计有些地方有问题,欢迎大家探讨一下这个问题。
评论
18 楼
ahuaxuan
2007-09-05
cacodemon 写道
-0-那就是你的第3个图画错了,怎么也不是tomcat cluster
让你一提醒我才注意到,其实我的图画的不严谨,第3个图中使用tomcat不是必需的,我画的是一种具体情况,也就是在tomcat的web应用中quartz集群的情况,我的图已经是具体到某一个具体场景了。事实上比较highlevel的图应该是这样的。
谢谢指正
17 楼
cacodemon
2007-09-05
ahuaxuan 写道
cacodemon 写道
你想的太多了,其实quartz已经把很多事情作完了。
正如他的文档描述的
你可以做jvm级的,使用rmi的cluster server,只需要配置一下xml。
正如他的文档描述的
你可以做jvm级的,使用rmi的cluster server,只需要配置一下xml。
你的这句话很容易让人产生误会,使用rmi的cluster server让人以为做cluster一定需要用rmi,其实不一定需要。
你上面贴出来的那个配置我当然知道啊,而且它的相关地址我在第8楼就贴出来了
http://wiki.opensymphony.com/display/QRTZ1/ConfigJDBCJobStoreClustering,
其实我说的第3种方案指得就是这一种。这种方式怎么能叫jvm级别的集群呢。这个是通过db来保证任务的执行的,所以当你说到
cacodemon 写道
我所说的不是这几种,因为不会用到tomcat cluster,而是jvm cluster,也是quartz自己提供的
我就以为这个是另外一种集群方式。
到现在我终于明白你说得集群就是我文中提到的第3种集群
-0-那就是你的第3个图画错了,怎么也不是tomcat cluster
16 楼
ahuaxuan
2007-09-05
cacodemon 写道
你想的太多了,其实quartz已经把很多事情作完了。
正如他的文档描述的
你可以做jvm级的,使用rmi的cluster server,只需要配置一下xml。
正如他的文档描述的
你可以做jvm级的,使用rmi的cluster server,只需要配置一下xml。
你的这句话很容易让人产生误会,使用rmi的cluster server让人以为做cluster一定需要用rmi,其实不一定需要。
你上面贴出来的那个配置我当然知道啊,而且它的相关地址我在第8楼就贴出来了
http://wiki.opensymphony.com/display/QRTZ1/ConfigJDBCJobStoreClustering,
其实我说的第3种方案指得就是这一种。这种方式怎么能叫jvm级别的集群呢。这个是通过db来保证任务的执行的,所以当你说到
cacodemon 写道
我所说的不是这几种,因为不会用到tomcat cluster,而是jvm cluster,也是quartz自己提供的
我就以为这个是另外一种集群方式,所以我就觉得自己对quartz的经验不够用了,居然还有基于rmi的quartz集群。
到现在我终于明白你说得集群就是我文中提到的第3种集群
15 楼
cacodemon
2007-09-05
我想你是不清楚如何來做jvm 的server吧
下面是個例子
quartzServerC1.properties:
#==============================================================
#Configure Main Scheduler Properties
#==============================================================
org.quartz.scheduler.instanceName = QuartzServer
org.quartz.scheduler.instanceId = ONE
# Configure RMI Properties ======================================================
org.quartz.scheduler.rmi.export = true
org.quartz.scheduler.rmi.registryHost = localhost
org.quartz.scheduler.rmi.registryPort = 1198
org.quartz.scheduler.rmi.serverPort = 0
org.quartz.scheduler.rmi.createRegistry = true
# Configure Logger(s) ======================================================
org.quartz.logger.schedLogger.class = org.quartz.simpl.SimpleLogger
org.quartz.logger.schedLogger.loggingPriority = 3
org.quartz.logger.schedLogger.outputFile =
org.quartz.logger.jsLogger.class = org.quartz.impl.Log4jLogger
org.quartz.logger.jsLogger.categoryName = scheduler.persistence
#==============================================================
#Configure ThreadPool
#==============================================================
org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPool
org.quartz.threadPool.threadCount = 5
org.quartz.threadPool.threadPriority = 5
#==============================================================
#Configure JobStore
#==============================================================
org.quartz.jobStore.misfireThreshold = 60000
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.useProperties=false
org.quartz.jobStore.dataSource = myDS
org.quartz.jobStore.isClustered = true
org.quartz.jobStore.clusterCheckinInterval = 20000
#==============================================================
#Non-Managed Configure Datasource
#==============================================================
org.quartz.dataSource.myDS.driver = oracle.jdbc.driver.OracleDriver
org.quartz.dataSource.myDS.URL = jdbc:oracle:thin:@:1521:
org.quartz.dataSource.myDS.user =
org.quartz.dataSource.myDS.password =
org.quartz.dataSource.myDS.maxConnections =
quartzServerC1.bat:
@SET LOG4J_PROPS="-Dlog4j.configuration=log4j.properties"
@SET QUARTZ_PROPS="-Dorg.quartz.properties=quartzServerC1.properties"
@SET RMI_POLICY="-Djava.security.policy=rmi.policy"
@SET LIB=e:\lib
@SET CLASSPATH=%CLASSPATH%;%LIB%
"java" -Dsun.net.client.defaultConnectTimeout=1200000 -Dsun.net.client.defaultReadTimeout=1200000 %RMI_POLICY% %LOG4J_PROPS% %QUARTZ_PROPS% com.scheduler.server.QuartzServer
以上是cluster中一個jvm server的配置
再次申明在其中配置rmi不是爲了cluster,是爲了web應用來操作job -0-
下面是個例子
quartzServerC1.properties:
#==============================================================
#Configure Main Scheduler Properties
#==============================================================
org.quartz.scheduler.instanceName = QuartzServer
org.quartz.scheduler.instanceId = ONE
# Configure RMI Properties ======================================================
org.quartz.scheduler.rmi.export = true
org.quartz.scheduler.rmi.registryHost = localhost
org.quartz.scheduler.rmi.registryPort = 1198
org.quartz.scheduler.rmi.serverPort = 0
org.quartz.scheduler.rmi.createRegistry = true
# Configure Logger(s) ======================================================
org.quartz.logger.schedLogger.class = org.quartz.simpl.SimpleLogger
org.quartz.logger.schedLogger.loggingPriority = 3
org.quartz.logger.schedLogger.outputFile =
org.quartz.logger.jsLogger.class = org.quartz.impl.Log4jLogger
org.quartz.logger.jsLogger.categoryName = scheduler.persistence
#==============================================================
#Configure ThreadPool
#==============================================================
org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPool
org.quartz.threadPool.threadCount = 5
org.quartz.threadPool.threadPriority = 5
#==============================================================
#Configure JobStore
#==============================================================
org.quartz.jobStore.misfireThreshold = 60000
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.useProperties=false
org.quartz.jobStore.dataSource = myDS
org.quartz.jobStore.isClustered = true
org.quartz.jobStore.clusterCheckinInterval = 20000
#==============================================================
#Non-Managed Configure Datasource
#==============================================================
org.quartz.dataSource.myDS.driver = oracle.jdbc.driver.OracleDriver
org.quartz.dataSource.myDS.URL = jdbc:oracle:thin:@:1521:
org.quartz.dataSource.myDS.user =
org.quartz.dataSource.myDS.password =
org.quartz.dataSource.myDS.maxConnections =
quartzServerC1.bat:
@SET LOG4J_PROPS="-Dlog4j.configuration=log4j.properties"
@SET QUARTZ_PROPS="-Dorg.quartz.properties=quartzServerC1.properties"
@SET RMI_POLICY="-Djava.security.policy=rmi.policy"
@SET LIB=e:\lib
@SET CLASSPATH=%CLASSPATH%;%LIB%
"java" -Dsun.net.client.defaultConnectTimeout=1200000 -Dsun.net.client.defaultReadTimeout=1200000 %RMI_POLICY% %LOG4J_PROPS% %QUARTZ_PROPS% com.scheduler.server.QuartzServer
以上是cluster中一個jvm server的配置
再次申明在其中配置rmi不是爲了cluster,是爲了web應用來操作job -0-
14 楼
cacodemon
2007-09-05
ahuaxuan 写道
to cacodemon
我有两个问题
1,那你说你的rmi在集群中到底起到了什么样的作用呢
2,按照你的描述quartz在集群时好像有两种方式,第一种是我的文章中所说的第3种方案,第2种是你所谓的jvm级别的cluster,你不停的让我去看文章,可是找了很多文章都没有发现你所说的jvm级别的cluster。
我甚至下载了Quartz Job Scheduling Framework这本书,在第11章quartz集群中我甚至没有发现rmi在集群时起到什么重要作用,我所说的第三种方案在集群时根本就不需要rmi。rmi不是集群的必须条件
而且从你的回贴中我也不能想象出你的rmi在集群中到底起到了什么作用
我有两个问题
1,那你说你的rmi在集群中到底起到了什么样的作用呢
2,按照你的描述quartz在集群时好像有两种方式,第一种是我的文章中所说的第3种方案,第2种是你所谓的jvm级别的cluster,你不停的让我去看文章,可是找了很多文章都没有发现你所说的jvm级别的cluster。
我甚至下载了Quartz Job Scheduling Framework这本书,在第11章quartz集群中我甚至没有发现rmi在集群时起到什么重要作用,我所说的第三种方案在集群时根本就不需要rmi。rmi不是集群的必须条件
而且从你的回贴中我也不能想象出你的rmi在集群中到底起到了什么作用
-0-我所有的回帖中都沒說rmi和集群有什麽關係!我都說了我只發現只有通過rmi接口來操作在jvm server上運行的job的
13 楼
ahuaxuan
2007-09-05
to cacodemon
我有两个问题
1,那你说你的rmi在集群中到底起到了什么样的作用呢
2,按照你的描述quartz在集群时好像有两种方式,第一种是我的文章中所说的第3种方案,第2种是你所谓的jvm级别的cluster,你不停的让我去看文章,可是找了很多文章都没有发现你所说的jvm级别的cluster。
我甚至下载了Quartz Job Scheduling Framework这本书,在第11章quartz集群中我甚至没有发现rmi在集群时起到什么重要作用,我所说的第三种方案在集群时根本就不需要rmi。rmi不是集群的必须条件
而且从你的回贴中我也不能想象出你的rmi在集群中到底起到了什么作用
我有两个问题
1,那你说你的rmi在集群中到底起到了什么样的作用呢
2,按照你的描述quartz在集群时好像有两种方式,第一种是我的文章中所说的第3种方案,第2种是你所谓的jvm级别的cluster,你不停的让我去看文章,可是找了很多文章都没有发现你所说的jvm级别的cluster。
我甚至下载了Quartz Job Scheduling Framework这本书,在第11章quartz集群中我甚至没有发现rmi在集群时起到什么重要作用,我所说的第三种方案在集群时根本就不需要rmi。rmi不是集群的必须条件
而且从你的回贴中我也不能想象出你的rmi在集群中到底起到了什么作用
12 楼
cacodemon
2007-09-05
ahuaxuan 写道
之前由于我对quartz的经验不够,所以说出了表示怀疑的话。我很想详细的学习一下你的做法,你能否把你的做法仔细阐述一下呢。
通过jvm的custer来做的话,那么如何通知其他node哪个job已经被执行或者是没有执行,时间同步问题你又是如何解决的呢。
而且你说通过一个web应用来调用rmi对jobserver进行任务的添加,但是这个不是rmi在jvm的cluster中的主要用途吧?多个节点上的quartz需要进行通信,我想你是不是通过rmi来进行通信的呢
1.如何通知其他node哪个job已经被执行或者是没有执行,多个节点上的quartz需要进行通信
這個是quartz cluster自己實現的,文檔代碼比較長,我建議你先看一下他的文檔 "quartz job scheduling framework"。另外,cluster必須是使用db的,所以對任務的操作基本上是基於他的JobStore的。
2.而且你说通过一个web应用来调用rmi对jobserver进行任务的添加,但是这个不是rmi在jvm的cluster中的主要用途吧?
因爲目前我只發現他提供的rmi的接口可以對jvm server上的job作操作。
3.时间同步问题
quartz提供了一個的解決方案(http://tf.nist.gov/service/its.htm),我還沒有試過。
另外可以做硬件server的cluster。
11 楼
ahuaxuan
2007-09-04
cacodemon 写道
我帮公司做了一个jvm cluster的,然后有一个web端通过rmi来新增job,
之前由于我对quartz的经验不够,所以说出了表示怀疑的话。我很想详细的学习一下你的做法,你能否把你的做法仔细阐述一下呢。
通过jvm的custer来做的话,那么如何通知其他node哪个job已经被执行或者是没有执行,时间同步问题你又是如何解决的呢。
而且你说通过一个web应用来调用rmi对jobserver进行任务的添加,但是这个不是rmi在jvm的cluster中的主要用途吧?多个节点上的quartz需要进行通信,我想你是不是通过rmi来进行通信的呢
10 楼
cacodemon
2007-09-04
ahuaxuan 写道
cacodemon 写道
我所说的不是这几种,因为不会用到tomcat cluster,而是jvm cluster,也是quartz自己提供的,所以不存在servlet资源不能释放的问题。
既它的文档上说的
quartzServerC1.properties:
org.quartz.scheduler.instanceName = QuartzServer
org.quartz.scheduler.instanceId = ONE
quartzServerC2.properties:
org.quartz.scheduler.instanceName = QuartzServer
org.quartz.scheduler.instanceId = TWO
这样就是他的cluster最简单的配置,当然你还需要配置她的Datasource,如果你需要及时提交job,那你还需要加上
org.quartz.scheduler.rmi.export = true
org.quartz.scheduler.rmi.registryHost = localhost
org.quartz.scheduler.rmi.registryPort = 1198
org.quartz.scheduler.rmi.serverPort = 0
org.quartz.scheduler.rmi.createRegistry = true
之类的,然后自己写个web应用或其他的来call他的rmi接口
既它的文档上说的
quartzServerC1.properties:
org.quartz.scheduler.instanceName = QuartzServer
org.quartz.scheduler.instanceId = ONE
quartzServerC2.properties:
org.quartz.scheduler.instanceName = QuartzServer
org.quartz.scheduler.instanceId = TWO
这样就是他的cluster最简单的配置,当然你还需要配置她的Datasource,如果你需要及时提交job,那你还需要加上
org.quartz.scheduler.rmi.export = true
org.quartz.scheduler.rmi.registryHost = localhost
org.quartz.scheduler.rmi.registryPort = 1198
org.quartz.scheduler.rmi.serverPort = 0
org.quartz.scheduler.rmi.createRegistry = true
之类的,然后自己写个web应用或其他的来call他的rmi接口
刚才google了一下,发现网上并没有quartz在jvm级别做集群得描述,
http://wiki.opensymphony.com/display/QRTZ1/ConfigRMI,这个页面是关于rmi配置的,在这里我丝毫没有看到cluster这个字眼。
http://wiki.opensymphony.com/display/QRTZ1/ConfigJDBCJobStoreClustering,这个页面是我所描述得关于jdbcjobstore的描述。
而且你说到
cacodemon 写道
当然你还需要配置她的Datasource
从上面那个连接来看,这个datasource的作用其实就是支持我说的第三种方案。
而且在用jdbcjobstore做集群的时候就是需要配置:
quartzServerC1.properties:
org.quartz.scheduler.instanceName = QuartzServer
org.quartz.scheduler.instanceId = ONE
quartzServerC2.properties:
org.quartz.scheduler.instanceName = QuartzServer
org.quartz.scheduler.instanceId = TWO
还有datasource,这些配置不是用到什么“jvm级别”的集群上的,却是在使用jdbcjobstore做集群时所需的配置
你说了用rmi做jvm级别的集群我认为并不存在,除非你拿出证据来,或者证明你确实这样做过
daquan198163 写道
jobserver作为hessian客户端,不需要是web容器吧?
你说的对,不过我是想如果可以的话可以做一个web端来监控quartz执行的状态,当然如果不需要这样做的话可以不用web容器。
我帮公司做了一个jvm cluster的,然后有一个web端通过rmi来新增job,
9 楼
ahuaxuan
2007-08-30
galaxystar 写道
我感觉第一种方式是比较实用, job业务逻辑, 一般都是比较独立或特殊的, 就算跟前端web的业务有重复, 拷贝一个jar过来, 也是很方便的.
重要得是, 控制在时间程序上的投入.
重要得是, 控制在时间程序上的投入.
第一种方案在不集群的情况下不能负载均衡啊,我还是认为这种三种方案应该是有不同的使用场景,应该试情况而定
8 楼
galaxystar
2007-08-28
我感觉第一种方式是比较实用, job业务逻辑, 一般都是比较独立或特殊的, 就算跟前端web的业务有重复, 拷贝一个jar过来, 也是很方便的.
重要得是, 控制在时间程序上的投入.
重要得是, 控制在时间程序上的投入.
7 楼
ahuaxuan
2007-08-28
cacodemon 写道
我所说的不是这几种,因为不会用到tomcat cluster,而是jvm cluster,也是quartz自己提供的,所以不存在servlet资源不能释放的问题。
既它的文档上说的
quartzServerC1.properties:
org.quartz.scheduler.instanceName = QuartzServer
org.quartz.scheduler.instanceId = ONE
quartzServerC2.properties:
org.quartz.scheduler.instanceName = QuartzServer
org.quartz.scheduler.instanceId = TWO
这样就是他的cluster最简单的配置,当然你还需要配置她的Datasource,如果你需要及时提交job,那你还需要加上
org.quartz.scheduler.rmi.export = true
org.quartz.scheduler.rmi.registryHost = localhost
org.quartz.scheduler.rmi.registryPort = 1198
org.quartz.scheduler.rmi.serverPort = 0
org.quartz.scheduler.rmi.createRegistry = true
之类的,然后自己写个web应用或其他的来call他的rmi接口
既它的文档上说的
quartzServerC1.properties:
org.quartz.scheduler.instanceName = QuartzServer
org.quartz.scheduler.instanceId = ONE
quartzServerC2.properties:
org.quartz.scheduler.instanceName = QuartzServer
org.quartz.scheduler.instanceId = TWO
这样就是他的cluster最简单的配置,当然你还需要配置她的Datasource,如果你需要及时提交job,那你还需要加上
org.quartz.scheduler.rmi.export = true
org.quartz.scheduler.rmi.registryHost = localhost
org.quartz.scheduler.rmi.registryPort = 1198
org.quartz.scheduler.rmi.serverPort = 0
org.quartz.scheduler.rmi.createRegistry = true
之类的,然后自己写个web应用或其他的来call他的rmi接口
刚才google了一下,发现网上并没有quartz在jvm级别做集群得描述,
http://wiki.opensymphony.com/display/QRTZ1/ConfigRMI,这个页面是关于rmi配置的,在这里我丝毫没有看到cluster这个字眼。
http://wiki.opensymphony.com/display/QRTZ1/ConfigJDBCJobStoreClustering,这个页面是我所描述得关于jdbcjobstore的描述。
而且你说到
cacodemon 写道
当然你还需要配置她的Datasource
从上面那个连接来看,这个datasource的作用其实就是支持我说的第三种方案。
而且在用jdbcjobstore做集群的时候就是需要配置:
quartzServerC1.properties:
org.quartz.scheduler.instanceName = QuartzServer
org.quartz.scheduler.instanceId = ONE
quartzServerC2.properties:
org.quartz.scheduler.instanceName = QuartzServer
org.quartz.scheduler.instanceId = TWO
还有datasource,这些配置不是用到什么“jvm级别”的集群上的,却是在使用jdbcjobstore做集群时所需的配置
你说了用rmi做jvm级别的集群我认为并不存在,除非你拿出证据来,或者证明你确实这样做过
daquan198163 写道
jobserver作为hessian客户端,不需要是web容器吧?
你说的对,不过我是想如果可以的话可以做一个web端来监控quartz执行的状态,当然如果不需要这样做的话可以不用web容器。
6 楼
daquan198163
2007-08-23
jobserver作为hessian客户端,不需要是web容器吧?
5 楼
cacodemon
2007-08-23
ahuaxuan 写道
loki 写道
那个讨论是老黄历了
另外没看出方案3有什么缺点
另外没看出方案3有什么缺点
首先说明一下老贴不代表没有价值
虽然第3种情况既能做到负载均衡,也能做到容错,但是也是有点代价的。
我觉得第3种方案有如下的缺点:
quartz需要使用jdbc-jobstore,quartz本身的性能减低。
所有节点所在机器的时间相差必须在一秒之内。
如果还有其他没有集群的quartz的话不能用这个jdbc-jobstore,不然可能会出问题。
所有的节点(web应用)都需要跑quartz实例,那么每个节点上都需要额外的线程池,而且参照前人的经验,如果考虑不周,
可能会导致servlet资源不能释放的问题。
还有一个是实现起来比较繁琐。
我所说的不是这几种,因为不会用到tomcat cluster,而是jvm cluster,也是quartz自己提供的,所以不存在servlet资源不能释放的问题。
既它的文档上说的
quartzServerC1.properties:
org.quartz.scheduler.instanceName = QuartzServer
org.quartz.scheduler.instanceId = ONE
quartzServerC2.properties:
org.quartz.scheduler.instanceName = QuartzServer
org.quartz.scheduler.instanceId = TWO
这样就是他的cluster最简单的配置,当然你还需要配置她的Datasource,如果你需要及时提交job,那你还需要加上
org.quartz.scheduler.rmi.export = true
org.quartz.scheduler.rmi.registryHost = localhost
org.quartz.scheduler.rmi.registryPort = 1198
org.quartz.scheduler.rmi.serverPort = 0
org.quartz.scheduler.rmi.createRegistry = true
之类的,然后自己写个web应用或其他的来call他的rmi接口
4 楼
ahuaxuan
2007-08-22
loki 写道
那个讨论是老黄历了
另外没看出方案3有什么缺点
另外没看出方案3有什么缺点
首先说明一下老贴不代表没有价值
虽然第3种情况既能做到负载均衡,也能做到容错,但是也是有点代价的。
我觉得第3种方案有如下的缺点:
quartz需要使用jdbc-jobstore,quartz本身的性能减低。
所有节点所在机器的时间相差必须在一秒之内。
如果还有其他没有集群的quartz的话不能用这个jdbc-jobstore,不然可能会出问题。
所有的节点(web应用)都需要跑quartz实例,那么每个节点上都需要额外的线程池,而且参照前人的经验,如果考虑不周,
可能会导致servlet资源不能释放的问题。
还有一个是实现起来比较繁琐。
3 楼
loki
2007-08-22
那个讨论是老黄历了
另外没看出方案3有什么缺点
另外没看出方案3有什么缺点
2 楼
ahuaxuan
2007-08-22
cacodemon 写道
你想的太多了,其实quartz已经把很多事情作完了。
正如他的文档描述的
你可以做jvm级的,使用rmi的cluster server,只需要配置一下xml。
正如他的文档描述的
你可以做jvm级的,使用rmi的cluster server,只需要配置一下xml。
我到不觉得我想太多了,而且第一种情况也不是我想出来的。
你说的情况就是文中所提的第3种情况,第3种情况有自己固有的缺点啊。
见正文,你的观点好像是不管什么情况,第3种方式一定是最合适的?
1 楼
cacodemon
2007-08-22
你想的太多了,其实quartz已经把很多事情作完了。
正如他的文档描述的
你可以做jvm级的,使用rmi的cluster server,只需要配置一下xml。
正如他的文档描述的
你可以做jvm级的,使用rmi的cluster server,只需要配置一下xml。
发表评论
-
过滤字符的性能调优?挤一挤还是有的
2010-05-29 05:54 3620/* *auth ... -
Master-Slave,Spring,Hibernate,故事曲折离奇,情结跌宕起伏
2009-02-05 13:49 8720/** *作者:张荣华 *日期 ... -
弃成见,反省,并重新认识struts.i18n.encoding
2008-12-24 15:42 3909[size=medium]之前和大家讨论了struts2.0中 ... -
关键字:查询,事务,粒度
2008-08-22 17:05 5159[size=medium]/** *作者: ... -
看看mina和memcached的联姻(适合不同语言客户端,高并发?)
2008-07-21 17:06 8022[size=medium]/** * 作者:张荣华 * 日 ... -
如何解决mysql的master-slave模式中ReplicationDriver的使用问题
2008-06-19 18:23 8236/** * 作者:张荣华 * 日期:2008-6-19 ... -
别装了,难道你们不想把properties直接注入到object中去(spring-plugin)?
2008-04-09 18:01 3668[size=small]/** *作者:张荣华(ahuaxu ... -
用jamon来监控你的sql执行效率
2008-02-25 15:48 3729/** *作者:张荣华 *日期:2008-2-25 ... -
java同msn的通信,大家想想用途吧
2007-11-24 17:14 2530程序员的生活真是单调,除了编程还是编程,工作日 ... -
EAI企业应用集成场景及解决方案
2007-09-21 18:21 3164/** *作者:张荣华(ahuaxuan) *2007-9 ... -
优化程序之前,可用Jamon来监测你的Spring应用
2007-08-14 18:14 8166/** *作者:张荣华(ahuaxuan) *2007-8-1 ... -
请问责任链真的是一种设计模式吗
2007-07-26 18:12 9459坛子上讨论设计模式的也挺多的,但是关于这个责任链模式还没有人提 ... -
把ActiveMQ的控制台整合到你的web程序中
2007-07-19 12:06 8876在使用ActiveMQ的时候把ActiveMQ的控制台整 ... -
设计模式之:解剖观察者模式
2007-07-17 16:12 6895[size=9] 论坛上很多人都 ... -
java邮件:在简单和复杂之间的方案
2007-07-11 18:07 7594/** *作者:张荣华(ahuaxu ... -
强强连手, 在模板中分页,看Freemarker和displaytag的结合
2007-07-09 09:22 6935/** *作者:张荣华(ahuaxuan) *2007-0 ... -
解惑:在spring+hibernate中,只读事务是如何被优化的。
2007-06-28 18:22 7632/** *作者:张荣华(ahuaxuan) *2007- ... -
让webwork零配置 第二章(实现)(实例已放出,大家可以下载运行)
2007-06-25 09:23 5731/** *作者:张荣华(ahuaxuan) *2007-0 ... -
让webwork2零配置,第一章(主贴再次更新)
2007-06-18 15:41 13434/** *作者:张荣华(ahuaxuan) *2007-0 ... -
Spring声明式事务管理源码解读之事务提交
2007-06-11 09:19 7293/** *作者:张荣华(ahuaxuan) *2007-0 ...
相关推荐
在实际应用中,你可能还会遇到如负载均衡、任务同步、节点间的通信等问题,需要对Quartz的API和原理有深入理解才能更好地应对。通过阅读官方文档、源码分析和实践操作,可以进一步掌握Quartz集群的精髓,提高系统...
总的来说,将Quartz2.2.1与Spring3.1.1集成并在集群环境中运行,需要深入理解Quartz的配置和Spring的bean管理,同时关注集群的稳定性和容错性。通过合理配置和编程,我们可以创建一个高效、可靠的定时任务执行系统。...
此外,还需要确保所有集群节点的时钟同步,避免因时间不一致导致的任务执行问题。 **5. 监控和管理** Quartz提供了一个Web界面——`Admin Console`,可以用来监控和管理作业和触发器。在集群环境中,每个节点都...
为了便于监控和管理Quartz集群,可以使用Web管理界面如`QuartzAdmin`或者通过API接口获取集群状态和任务信息。 9. **源码阅读**: 对于深入理解Quartz集群的工作原理,阅读源码是一个很好的途径。了解`Cluster...
SpringBoot整合Quartz实现定时任务调度是企业级应用中常见的需求,主要用于自动化执行某些周期性的任务,例如数据备份、报表生成、系统维护等。Quartz是一个功能强大的开源作业调度框架,能够灵活地定义任务和调度...
在IT行业中,Spring框架和Quartz库是两个非常重要的组件,它们在企业级应用开发中发挥着关键作用。本文将详细讲解如何结合Spring 4.0.6版本和Quartz 2.2.3版本来实现一个集群示例,帮助你理解和掌握相关知识点。 ...
3. **监控和管理**: 实现对Quartz集群的监控,如任务状态、运行时性能等,以便及时发现和解决问题。 总结,Quartz+Spring的分布式集群调度方案能够帮助开发者构建稳定且可扩展的定时任务系统。通过合理配置和实践,...
Quartz是一款开源的作业调度框架,它允许程序在特定时间执行预定的任务,而Spring则是一个强大的企业级应用开发框架,提供了丰富的依赖注入(DI)和面向切面编程(AOP)等功能。将两者结合,可以方便地在Spring应用...
本解决方案通过将 Quartz 的任务实例化至数据库、合理配置 Quartz 属性文件以及利用 Spring 框架进行重构等手段,有效地解决了集群环境下 Quartz 部署和管理的问题。不仅可以避免任务的重复执行,还能确保系统的高...
Quartz集群是为了实现高可用性和负载均衡,当一个节点故障时,其他节点能够接管任务,保证服务不中断。 在Quartz集群中,数据库扮演了至关重要的角色,因为它存储了所有关于作业和触发器的信息。集群中的各个节点...
标题 "spring quartz 集群模式" 涉及到的是Spring框架与Quartz调度器在集群环境下的集成和配置。Quartz是一个开源任务调度框架,而Spring则提供了与Quartz的无缝集成,使得在Java应用中管理和执行定时任务变得更加...
2. **故障恢复策略**:通过配置`org.quartz.jobStore.isClustered=true`,确保集群节点间的心跳和失败检测。 3. **任务持久化**:Quartz将任务和触发器存储在数据库中,即使应用重启,也能保持任务状态。 4. **异常...
- 考虑使用监控工具(如Prometheus+Grafana)监控Quartz集群的运行状态,以便及时发现和解决问题。 通过以上知识点的学习和实践,开发者可以熟练掌握在Spring环境中使用Quartz实现分布式集群的作业调度,提升系统...
Quartz集群配置是一项重要的技术,它可以确保在多个服务器之间分布任务,提高系统的可用性和容错性。集群模式下,如果一个节点失败,其他节点可以接管工作,保持服务的连续性。 在Quartz集群配置中,主要涉及以下几...
集成Quartz集群需要配置Quartz的集群模式,包括共享的数据存储(如数据库)、集群节点间的通信机制(如JDBC Job Store)以及对Job和Trigger的一致性处理。在实际应用中,可能会使用如ZooKeeper这样的分布式协调服务...
Quartz和Spring Batch是两种非常重要的Java开源框架,它们在企业级应用开发中扮演着重要角色。Quartz主要用于任务调度,而Spring Batch则专注于批量处理。在这个“quartz_springbatch_dynamic”项目中,我们将看到...
在Quartz集群中,每个节点都是一个独立的Quartz应用,它们通过共享数据库来感知彼此的存在。这种设计使得集群具有高可用性和伸缩性。当任务触发时间到来时,第一个获取到任务的节点会执行任务,实现了负载均衡。如果...