Quartz Scheduler在Web应用程序中
我正在学习石英,并尝试了一些适用于控制台应用程序的示例。 现在我正在尝试在网络应用程序。 以下是我所做的。
web.xml中
<?xml version="1.0" encoding="UTF-8"?>
<web-app>
<servlet>
<servlet-name>QuartzInitializer</servlet-name>
<display-name> Quartz Initializer Servlet</display-name>
<servlet-class>org.quartz.ee.servlet.QuartzInitializerServlet</servlet-class>
<load-on-startup>1</load-on-startup>
<init-param>
<param-name>config-file</param-name>
<param-value>quartz.properties</param-value>
</init-param>
<init-param>
<param-name>shutdown-on-unload</param-name>
<param-value>true</param-value>
</init-param>
<init-param>
<param-name>start-scheduler-on-load</param-name>
<param-value>true</param-value>
</init-param>
</servlet>
</web-app>
quartz.properties
org.quartz.plugin.jobInitializer.class = org.quartz.plugins.xml.XMLSchedulingDataProcessorPlugin
org.quartz.plugin.jobInitializer.fileNames = quartz-config.xml
org.quartz.plugin.jobInitializer.failOnFileNotFound = true
org.quartz.plugin.jobInitializer.scanInterval = 10
org.quartz.plugin.jobInitializer.wrapInUserTransaction = false
# Configuring ThreadPool
org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPool
org.quartz.threadPool.threadCount = 30
org.quartz.threadPool.threadPriority = 5
石英-config.xml中
<?xml version="1.0" encoding="UTF-8"?>
<job-scheduling-data
xmlns="http://www.quartz-scheduler.org/xml/JobSchedulingData"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.quartz-scheduler.org/xml/JobSchedulingData http://www.quartz-scheduler.org/xml/job_scheduling_data_1_8.xsd"
version="1.8">
<pre-processing-commands>
<delete-jobs-in-group>*</delete-jobs-in-group> <!-- clear all jobs in scheduler -->
<delete-triggers-in-group>*</delete-triggers-in-group> <!-- clear all triggers in scheduler -->
</pre-processing-commands>
<processing-directives>
<overwrite-existing-data>true</overwrite-existing-data>
<ignore-duplicates>false</ignore-duplicates>
</processing-directives>
<schedule>
<job>
<name>MyJob</name>
<job-class>com.kaplan.external.quartz.KpubScheduler</job-class>
</job>
<trigger>
<simple>
<name>TenSecondIntervals</name>
<job-name>MyJob</job-name>
<repeat-count>-1</repeat-count> <!-- repeat forever -->
<repeat-interval>10000</repeat-interval> <!-- every 10 seconds -->
</simple>
</trigger>
</schedule>
</job-scheduling-data>
KpubScheduler.java
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;
import org.quartz.StatefulJob;
public class KpubScheduler implements StatefulJob {
protected static final Log log = LogFactory.getLog(KpubScheduler.class);
public void execute(JobExecutionContext context) throws JobExecutionException {
try {
System.out.println("Quartz Config..........");
log.info("entering the quartz config");
} catch (Exception ex) {
log.info("entering the quartz config");
}
}
}
现在我已经启动了服务器。 开始之后,我的KpubScheduler必须被调用,我应该得到日志信息和Sysout的。 但没有任何事情发生。 如果我看看日志,只要给它
Dec 29, 2010 8:21:37 PM org.apache.catalina.core.ApplicationContext log
INFO: QuartzInitializer: Scheduler has been started...
Dec 29, 2010 8:21:37 PM org.apache.catalina.core.ApplicationContext log
INFO: QuartzInitializer: Storing the Quartz Scheduler Factory in the servlet context at key: org.quartz.impl.StdSchedulerFactory.KEY
可能是什么问题? 我做对了吗?
这在理论上似乎没问题,但是你的意思是这个<pre-processing-commands />
的用法可能会被删除吗? 你可以尝试没有他们吗?
我的应用程序看起来像你的,但我用Quartz没有问题。
您确定您确实为KpubScheduler配置了正确的日志级别吗?
链接地址: http://www.djcxy.com/p/4043.html上一篇: Quartz Scheduler in Web application
下一篇: Undoing a 'git push'