前几天项目的中采用了定时任务计算,开始运行的好好的,但是过了一段时间之后,发现spring的两种配置。有些小体会!
配置1:cronExpression
<bean id="XXXXJob" class="org.springframework.scheduling.quartz.JobDetailBean">
<property name="jobClass">
<value>
XXX.XXX.XXX.XXX.XXX.XXX.XXX.XXXXJob
</value>
</property>
</bean>
<bean id="XXXXXJobTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean">
<property name="jobDetail" ref="XXXXJob" />
<property name="startDelay">
<value>3000</value>
</property>
<property name="cronExpression">
<value>*/50 * * * * ?</value>
</property>
</bean>
采用了表达式形式,具体表达式的配置就不在累赘了,这里主要想实现每50秒运行一次,但这个有问题!
console出现的结果如下:
开始执行时间是2015-01- 12 17:43:50.002,下次执行的时间应该是2015-01- 12 17:44:40.002,但是程序并没有按照正常的逻辑输出,每次超过1分钟都会在运行一次,导致job的调度错误,其原因还没有弄明白!
配置2:repeatInterval
<bean id="XXXXJob" class="org.springframework.scheduling.quartz.JobDetailBean">
<property name="jobClass">
<value>
XXXX.XXXX.XXXX.XXXX.XXXX.XXXX.XXXX.XXXXJob
</value>
</property>
</bean>
<bean id="XXXXJobTrigger" class="org.springframework.scheduling.quartz.SimpleTriggerBean">
<property name="jobDetail" ref="XXXXJob" />
<property name="startDelay">
<value>3000</value>
</property>
<property name="repeatInterval">
<value>50000</value>
</property>
</bean>
console出现的结果如下:
从结果上看,是正确的。
总的说来,两种比较第一种采用cronExpression表达式配置,适合业务比较复杂的;第二种比较简单,适合简单的任务调度。第一种如果执行的周期超过30s,就存在那样的问题。为什么第一种不能够实现功能,正在研究中。。。。