Как использовать кварц с QuartzInitializerListener?

у меня возникли проблемы с пониманием того, как использовать кварц с QuartzInitializerListener.

сначала я объявляю этот прослушиватель в дескрипторе развертывания. Но тогда, как я могу добавить свою работу? Взглянув на реализация QuartzInitializerListener, Я вижу, что он создает SchedulerFactory и Scheduler, но я не вижу никакого способа добавить задания. Фабрика получает конфигурационный файл, но опять же нет ничего, связанного с работой там.

Я нашел только очень простые примеры из моих поисков, все о создании всего в основной способ.

может ли кто-нибудь указать мне на более реальный пример? Я использую JBoss 5, если это имеет значение. Спасибо.

2 ответов


все описано в исходный код Javadoc вы цитируете:

экземпляр StdSchedulerFactory хранится в ServletContext. Вы можете получить доступ на фабрику из экземпляра ServletContext, как это:

StdSchedulerFactory factory = (StdSchedulerFactory) ctx
       .getAttribute(QuartzInitializerListener.QUARTZ_FACTORY_KEY);

редактировать: это означает, что при использовании этого слушателя вы можете получить SchedulerFactory внутри каждого сервлета / пружинного контроллера MVC/... бегом:

StdSchedulerFactory factory = (StdSchedulerFactory)httpServletRequest
    .getServletContext()
    .getAttribute(QuartzInitializerListener.QUARTZ_FACTORY_KEY);

обратите внимание, что контекст прослушиватели гарантированно будут выполнены до того, как какой-либо сервлет будет использоваться для обработки входящих запросов. Это означает, что планировщик всегда будет правильно инициализирован до его использования.


резюме обсуждения в комментариях ниже, обсуждение на самом деле отвечает на заданный вопрос: если вы хотите добавить задания при запуске приложения, напишите другой прослушиватель (аналогичный тому, который предоставляет Quartz), lookup StdSchedulerFactory (ServletContext легко доступен) и делать то, что вы хотите. Слушатели гарантированно выполняются в том же порядке, в каком они объявлены в интернете.xml, поэтому поставьте своего слушателя после Quartz one.


привет вот ответ на ваш запрос:

1) Шаг 1: Напишите Задание:

package com.hitesh.quartz.test;

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

public class QuartzJob implements Job {

    @Override
    public void execute(JobExecutionContext arg0) throws JobExecutionException {
        System.out.println("Hello");

    }

}

2) написать web.XML-код:

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
    xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
    id="WebApp_ID" version="2.5">
    <display-name>TestWebBasedQuartz</display-name>
    <welcome-file-list>
        <welcome-file>index.html</welcome-file>
        <welcome-file>index.htm</welcome-file>
        <welcome-file>index.jsp</welcome-file>
        <welcome-file>default.html</welcome-file>
        <welcome-file>default.htm</welcome-file>
        <welcome-file>default.jsp</welcome-file>
    </welcome-file-list>
    <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>true</param-value>
    </context-param>

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

    <listener>
        <listener-class>com.hitesh.quartz.test.QuartzJobListener</listener-class>
    </listener>
</web-app>

как вы можете видеть есть два слушателей. Один принадлежит Quartz API, а другой-вашему API. Первый слушатель Quartz API будет выполняться так, как он приходит первым в порядке. На данный момент у нас будет готовый планировщик фабрики. Этот прослушиватель также запустит планировщик, если соответствующее свойство "quartz:start-on-load" либо не указано, либо не указано как истинные.

3) Напишите свой кварцевый слушатель:

package com.hitesh.quartz.test;


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

import org.quartz.JobBuilder;
import org.quartz.JobDetail;
import org.quartz.Scheduler;
import org.quartz.SchedulerException;
import org.quartz.SimpleScheduleBuilder;
import org.quartz.Trigger;
import org.quartz.TriggerBuilder;
import org.quartz.ee.servlet.QuartzInitializerListener;
import org.quartz.impl.StdSchedulerFactory;

public class QuartzJobListener implements ServletContextListener {

    private Scheduler scheduler;
    @Override
    public void contextDestroyed(ServletContextEvent arg0) {

    }

    @Override
    public void contextInitialized(ServletContextEvent ctx) {
        JobDetail job = JobBuilder.newJob(QuartzJob.class)
        .withIdentity("dummyJobName", "group1").build();

        Trigger trigger = TriggerBuilder
        .newTrigger()
        .withIdentity("dummyTriggerName", "group1")
        .withSchedule(
            SimpleScheduleBuilder.simpleSchedule()
                .withIntervalInSeconds(1).repeatForever())
        .build();
        try{
            scheduler = ((StdSchedulerFactory) ctx.getServletContext().getAttribute(QuartzInitializerListener.QUARTZ_FACTORY_KEY)).getScheduler();
            scheduler.scheduleJob(job, trigger);    
        }catch(SchedulerException e){

        }


    }



}

этот прослушиватель будет выполняться после выполнения Quartz listener. Это значит что мы имеем готовую сделанную фабрику планировщика с нами и начатым планировщиком. Поэтому вам нужно только добавить задание в планировщик. Как вы можете видеть, метод contextDestroyed пуст, так как работа выключения планировщика будет выполняться Quartz API schedluer.