Spring tomcat+;弹簧&x2B;石英=关机错误

Spring tomcat+;弹簧&x2B;石英=关机错误,spring,tomcat,quartz-scheduler,Spring,Tomcat,Quartz Scheduler,我们正在尝试做一件看起来非常简单的事情,但它不起作用,而且我在网上找到的解决方案对于如此基本的事情来说似乎很复杂,所以我觉得我应该再问一次。 我们有一个在tomcat下运行的SpringWeb应用程序。我们向其中添加了Quartz调度程序: <bean id="myScheduler" class="org.springframework.scheduling.quartz.SchedulerFactoryBean"> <property name="dataSou

我们正在尝试做一件看起来非常简单的事情,但它不起作用,而且我在网上找到的解决方案对于如此基本的事情来说似乎很复杂,所以我觉得我应该再问一次。 我们有一个在tomcat下运行的SpringWeb应用程序。我们向其中添加了Quartz调度程序:

<bean id="myScheduler" class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
      <property name="dataSource" ref="myDataSource"/>
      <property name="transactionManager" ref="myTransactionManager"/>

      <property name="overwriteExistingJobs" value="true"/>

      <property name="autoStartup" value="true"/>

      <property name="jobFactory">
         <bean class="AutowiringSpringBeanJobFactory"/>
      </property>

      <!-- NOTE: Must add both the jobDetail and trigger to the scheduler! -->
      <property name="jobDetails">
         <list>
            <ref bean="jobDetailAutoSendPublishedReport" />
         </list>
      </property>
      <property name="triggers">
         <list>
            <ref bean="cronTriggerAutoSendPublishedReport"/>
         </list>
      </property>

      <property name="quartzProperties">
         <props>
            <!-- Main Scheduler Properties For A Clustered Scheduler -->
            <prop key="org.quartz.scheduler.instanceName">test</prop>
            <prop key="org.quartz.scheduler.instanceId">AUTO</prop>
            <prop key="org.quartz.scheduler.skipUpdateCheck">true</prop>
            <prop key="org.quartz.scheduler.idleWaitTime">60000</prop>

            <!-- ThreadPool -->
            <prop key="org.quartz.threadPool.class">org.quartz.simpl.SimpleThreadPool</prop>
            <prop key="org.quartz.threadPool.threadCount">5</prop>

            <!-- Shutdown Hook Plugin -->
            <!--prop key="org.quartz.plugin.shutdownhook.class">org.quartz.plugins.management.ShutdownHookPlugin</prop>
            <prop key="org.quartz.plugin.shutdownhook.cleanShutdown">true</prop-->

            <!-- JDBC JobStore -->
            <prop key="org.quartz.jobStore.class">org.quartz.impl.jdbcjobstore.JobStoreTX</prop>
            <prop key="org.quartz.jobStore.driverDelegateClass">org.quartz.impl.jdbcjobstore.oracle.OracleDelegate</prop>
            <prop key="org.quartz.jobStore.useProperties">false</prop>
            <prop key="org.quartz.jobStore.isClustered">true</prop>
            <prop key="org.quartz.jobStore.clusterCheckinInterval">300000</prop>
            <prop key="org.quartz.jobStore.misfireThreshold">300000</prop>
         </props>
      </property>
   </bean>

测试
自动的
真的
60000
org.quartz.siml.SimpleThreadPool
5.
org.quartz.impl.jdbcjobstore.JobStoreTX
org.quartz.impl.jdbcjobstore.oracle.OracleDelegate
假的
真的
300000
300000
然后,当我试图关闭tomcat时,我得到了以下错误,tomcat将关闭:

似乎已启动名为[DefaultQuartzScheduler\u QuartzSchedulerThread]的线程,但未能停止该线程。这很可能会造成内存泄漏。 2015年1月27日凌晨1:09:35 org.apache.catalina.loader.WebappClassLoader检查线程LocalMapForLeaks

我的解决方案是将以下内容添加到web.xml:

 <!-- Start Quartz -->
   <listener>
      <listener-class>
         org.quartz.ee.servlet.QuartzInitializerListener
      </listener-class>
   </listener>
   <context-param>
      <param-name>quartz:shutdown-on-unload</param-name>
      <param-value>true</param-value>
   </context-param>
   <context-param>
      <param-name>quartz:wait-on-shutdown</param-name>
      <param-value>true</param-value>
   </context-param>
   <context-param>
      <param-name>quartz:start-on-load</param-name>
      <param-value>false</param-value> <!-- let spring handle starting -->
   </context-param>
   <!-- End of Quartz -->

org.quartz.ee.servlet.QuartzInitializerListener
石英:卸载时关机
真的
石英:等待关机
真的
石英:负载启动
假的
中的内容如下:

如果您正在使用org.quartz.ee.servlet.QuartzInitializerListener启动servlet容器中的计划程序,则当您的应用程序取消部署或应用程序服务器关闭时,其contextDestroyed()方法将关闭计划程序

也许你也可以添加这个监听器