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