Как использовать кварц с 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.
