当前位置: 代码迷 >> J2EE >> spring定时器启动了但不执行任务,该如何解决
  详细解决方案

spring定时器启动了但不执行任务,该如何解决

热度:6   发布时间:2016-04-22 02:08:49.0
spring定时器启动了但不执行任务
application.xml中定时器相关的配置:
XML code
<bean id="mediaManager" name="mediaManager"        class="cn.biz.datacenter.basedata.impl.MediaManager">        <aop:scoped-proxy proxy-target-class="false" />    </bean> <bean id="buildMediaList"        class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">      <property name="targetObject" ref="mediaManager" />      <property name="targetMethod" value="buildMediaList" />    </bean><bean id="buildMediaListTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean">        <property name="jobDetail" ref="buildMediaList" />        <property name="cronExpression" value="10 25 17 * * ?" />    </bean> <bean class="org.springframework.scheduling.quartz.SchedulerFactoryBean">        <property name="triggers">            <list>                <ref bean="buildMediaListTrigger" />                            </list>        </property>    </bean>


应用启动时定时器部分的启动日志:
Java code
Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImplQuartz Scheduler v.1.6.5 created.RAMJobStore initialized.Quartz scheduler 'catcherScheduler' initialized from an externally provided properties instance.Quartz scheduler version: 1.6.5JobFactory set to: org.springframework.scheduling.quartz.AdaptableJobFactory@11669f2Starting Quartz Scheduler nowScheduler catcherScheduler_$_NON_CLUSTERED started.==================== Startup CatcherManager ====================Fetch all BSD_SCHEDULE, and put them into MAPHibernate: select bsd_schedu0_.ID as ID43_, bsd_schedu0_.NAME as NAME43_, bsd_schedu0_.RUNNING_TYPE as RUNNING3_43_, bsd_schedu0_.RUNNING_PARAM as RUNNING4_43_, bsd_schedu0_.SCHEDULE_TYPE as SCHEDULE5_43_, bsd_schedu0_.YEAR as YEAR43_, bsd_schedu0_.MONTH as MONTH43_, bsd_schedu0_.DAY as DAY43_, bsd_schedu0_.WEEK as WEEK43_, bsd_schedu0_.HOUR as HOUR43_, bsd_schedu0_.MINUTE as MINUTE43_, bsd_schedu0_.CRON as CRON43_, bsd_schedu0_.JOB_NAME as JOB13_43_, bsd_schedu0_.PRIORITY as PRIORITY43_, bsd_schedu0_.SYSTEM_TASK as SYSTEM15_43_, bsd_schedu0_.AVAILABLE as AVAILABLE43_, bsd_schedu0_.OLD_SID as OLD17_43_ from icrom.BSD_SCHEDULE bsd_schedu0_ where bsd_schedu0_.AVAILABLE=1Add CatcherJobListener to CatcherScheduler.Arrange all BSD_SCHEDULE into, and put them into CatcherScheduler.Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImplQuartz Scheduler v.1.6.5 created.RAMJobStore initialized.Quartz scheduler 'org.springframework.scheduling.quartz.SchedulerFactoryBean#0' initialized from an externally provided properties instance.Quartz scheduler version: 1.6.5JobFactory set to: org.springframework.scheduling.quartz.AdaptableJobFactory@1e9d810Starting Quartz Scheduler nowScheduler org.springframework.scheduling.quartz.SchedulerFactoryBean#0_$_NON_CLUSTERED started.


根据配置,此任务应该是在下午5点25分执行的,但应用确没有执行,
请各位前辈帮忙看看是哪里出问题了!
谢谢

------解决方案--------------------
<bean id="buildMediaList" 
class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
<property name="targetObject" ref="mediaManager" />
<property name="targetMethod" value="buildMediaList" />
</bean>
这里错了吧,这里是执行的函数名字,应该这样写吧
<property name="targetMethod"><value>buildMediaList</value></property> 。
  相关解决方案