主题:spring集成quartz,出现2次重复调用的问题

在项目中使用了quartz的任务调度,在本地测试的时候没有问题,只会调用1次部署到服务器上后,发现同一个任务,在相同的时间被调用了2次。本地环境 windowsXP ,spring2.5.1, sun的JDK 1.5, TOMCAT6 服务器环境 linux, jrockit-R27.3.1-jdk1.5.0_11, TOMCAT6 ,spring2.5.1 spring 配置文件: <bean id="targetJob" parent="txProxyTemplate" singleton="true">        <property name="target">            <bean class="com.service.impl.TaskServiceImpl">                <property name="baseHibernateDao">                 <ref bean="baseHibernateDao"/>                </property>            </bean>        </property>    </bean>       <bean id="jobDetail" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">     <property name="targetObject">      <ref bean="targetJob"/>     </property>     <property name="targetMethod">      <value>doJob</value>     </property>     <property name="concurrent" value="false" />   </bean>         <bean id="jobTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean"">  <property name="jobDetail">   <ref bean="jobDetail"/>  </property>  <property name="cronExpression">    <value>0 0/10 * * * ?</value>     </property>    </bean>     <bean id="z" class="org.springframework.scheduling.quartz.SchedulerFactoryBean">  <property name="triggers">   <list>    <ref local="jobTrigger"/>      </list>  </property>     </bean> 查看了本地和服务器的LOG日志,打印到DEBUG 发现在服务器的日志中,下面的信息出现了2次,而在本地只有1次,这个是不是意味着 这个类被实例化了2次,所以才会出现同时调用2次的结果Creating shared instance of singleton bean 'jobDetail'Creating instance of bean 'jobDetail' with merged definition [Root bean: class [org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean]; scope=singleton; abstract=false; lazyInit=false; autowireCandidate=true; autowireMode=0; dependencyCheck=0; factoryBeanName=null; factoryMethodName=null; initMethodName=null; destroyMethodName=null; defined in ServletContext resource [/WEB-INF/spring-service.xml]]Eagerly caching bean 'jobDetail' to allow for resolving potential circular referencesReturning cached instance of singleton bean 'targetJob' 希望大家能给出 解决方案 谢谢~~~~   是TOMCAT配置出了问题   应大家要求,解释一下原因,是TOMCAT的配置文件server.xml配置不当引起的,请看下面这段配置就是错误的: <Host name="www.***.com" debug="0" appBase="webapps" unpackWARs="true" autoDeploy="true" xmlValidation="false" xmlNamespaceAware="false"> <Logger className="org.apache.catalina.logger.FileLogger" directory="logs" prefix="localhost_log." suffix=".txt" timestamp="true" /> <Context path="" docBase="/tomcat/webapps/***" debug="1" /> <Context path="/***2" docBase="/tomcat/webapps/***2" debug="1" /> </Host> 正确的配置如下 <Host name="www.***.com" debug="0" appBase="" unpackWARs="true" autoDeploy="true" xmlValidation="false" xmlNamespaceAware="false"> <Logger className="org.apache.catalina.logger.FileLogger" directory="logs" prefix="localhost_log." suffix=".txt" timestamp="true" /> <Context path="" docBase="/tomcat/webapps/***" debug="1" /> <Context path="/***2" docBase="/tomcat/webapps/***2" debug="1" /> </Host> 这两段的区别是第二段去除了appBase="webapps"中的webapps变成了appBase="",因为web应用程序都是放在webapps这个目录下的,如果不把“webapps“去掉,这里会调用一次quartz的任务调度,在接下来的“<Context path”中又会调用一次quartz的任务调度,所以就重复了2次

你可能感兴趣的:(spring,tomcat,bean,quartz,Class,任务调度)