1

Tomcat の起動時に Quartz プロセスを開始しようとしていますが、機能していません。これが私の簡単なコードです: My ServletContextListener:

パッケージ Quartz.test;

 import javax.servlet.ServletContext;
 import javax.servlet.ServletContextEvent;
 import javax.servlet.ServletContextListener;

 import org.apache.log4j.Logger;
 import org.quartz.CronScheduleBuilder;
 import org.quartz.JobBuilder;
 import org.quartz.JobDetail;
 import org.quartz.Scheduler;
 import org.quartz.SchedulerException;
 import org.quartz.Trigger;
 import org.quartz.TriggerBuilder;
 import org.quartz.impl.StdSchedulerFactory;

 public class ApplicationStartup implements ServletContextListener {
private static Logger log = Logger.getLogger(ApplicationStartup.class);
 public static final String QUARTZ_FACTORY_KEY = "org.quartz.impl.StdSchedulerFactory.KEY";
 private StdSchedulerFactory factory = null;

public void contextDestroyed(ServletContextEvent event) {
    try
    {
        factory.getDefaultScheduler().shutdown();
    } catch (SchedulerException ex)
    {
        log.info("catch");
    }
}

public void contextInitialized(ServletContextEvent sce) {

    System.out.println("THE APPLICATION STARTED");
    ServletContext ctx = sce.getServletContext();

    JobDetail job = JobBuilder.newJob(HelloJob.class).withIdentity("dummyJobName", "group1").build();

    Trigger trigger = TriggerBuilder.newTrigger().withIdentity("dummyTriggerName", "group1")
    .withSchedule(CronScheduleBuilder.cronSchedule("0/5 * * * * ?")).build();

    try {
        factory = new StdSchedulerFactory();
        ctx.setAttribute(QUARTZ_FACTORY_KEY, factory);
        Scheduler scheduler= factory.getScheduler();
        scheduler.start();
        scheduler.scheduleJob(job, trigger);
    } catch (SchedulerException e) {
        e.printStackTrace();
    }


}

} 私の仕事:

package quartz.test;

import org.quartz.Job;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;

public class HelloJob implements Job
{
    public void execute(JobExecutionContext context) throws JobExecutionException {

        System.out.println("Hello Quartz!");
    }
}

web.xml

     <context-param>
     <param-name>quartz:shutdown-on-unload</param-name>
     <param-value>false</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-scheduler-on-load</param-name>
     <param-value>true</param-value>
 </context-param>
 <context-param>
     <param-name>quartz:config-file</param-name>
     <param-value>/WEB-INF/classes/quartz.properties</param-value>
 </context-param>

 <listener>
     <listener-class>
        org.quartz.ee.servlet.QuartzInitializerListener
     </listener-class>
 </listener>

編集: ジョブが開始されましたが、エラーが発生しています: 20/08/2013 11:18:19 org.apache.catalina.loader.WebappClassLoader clearReferencesThreads SEVERE: Web アプリケーション [/monitor] は、[ という名前のスレッドを開始したようです。 QuartzTest_Worker-1] ですが、停止に失敗しました。これにより、メモリ リークが発生する可能性が非常に高くなります。

アプリケーションをTomcatに再デプロイするときにサーバー上で助けてください

ありがとう、

4

2 に答える 2

1

解決策を見つけました。Quartz ジョブの依存関係のバグのようです。それを機能させるには、これを maven に追加します。

        <dependency>
        <groupId>log4j</groupId>
        <artifactId>log4j</artifactId>
        <version>1.2.16</version>
    </dependency>

    <dependency>
        <groupId>org.quartz-scheduler</groupId>
        <artifactId>quartz-jobs</artifactId>
        <version>2.2.0</version>
    </dependency>

    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-api</artifactId>
        <version>1.6.6</version>
    </dependency> 

このバグはバージョン 2.2.0 のみで、バージョン 2.1.6 では問題なく動作しています。

于 2013-08-20T12:17:32.987 に答える
0

この例を実行するには、Quartz から少なくとも 2 つの jar ファイルが必要です。

quartz-2.2.x.jar
quartz-jobs-2.2.x.jar
于 2014-09-16T11:15:07.600 に答える