Quartz Scheduler Quartz Is A Product of Terracotta
NEWS: Quartz 1.7.3 has been released.

How-To: Initializing Job Data With Scheduler Initialization

You can initialize the scheduler with predefined jobs and triggers using the JobInitializationPlugin. An example is provided in the Quartz distribution in the directory examples/example10. However, following is a short description of how the plugin works.

First of all, we need to explicitly specify in the scheduler properties that we want to use the JobInitializationPlugin. This is an excerpt from an example quartz.properties:

#===================================================
# Configure the Job Initialization Plugin
#===================================================

org.quartz.plugin.jobInitializer.class = org.quartz.plugins.xml.JobInitializationPlugin
org.quartz.plugin.jobInitializer.fileNames = jobs.xml
org.quartz.plugin.jobInitializer.overWriteExistingJobs = true
org.quartz.plugin.jobInitializer.failOnFileNotFound = true
org.quartz.plugin.jobInitializer.scanInterval = 10
org.quartz.plugin.jobInitializer.wrapInUserTransaction = false

Let's see what each property does:

The jobs.xml file (or any other name you use for it in the fileNames init plugin property) declaratively defines jobs, triggers, calendars and the association between jobs and triggers. Here's an autoexplicative example:

<?xml version='1.0' encoding='utf-8'?>
<quartz xmlns="http://www.quartz-scheduler.org/JobSchedulingData"
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://www.quartz-scheduler.org/JobSchedulingData
  http://www.quartz-scheduler.org/xml/job_scheduling_data_1_5.xsd"
  version="1.5">

    <job>
        <job-detail>
            <name>my-very-clever-job</name>
            <group>MYJOB_GROUP</group>

            <description>The job description</description>
            <job-class>com.acme.scheduler.job.CleverJob</job-class>
            <job-data-map allows-transient-data="false">

                <entry>
                    <key>burger-type</key>
                    <value>hotdog</value>
                </entry>
                <entry>

                    <key>dressing-list</key>
                    <value>ketchup,mayo</value>
                </entry>
            </job-data-map>
        </job-detail>

        <trigger>
            <cron>
                <name>my-trigger</name>
                <group>MYTRIGGER_GROUP</group>
                <job-name>my-very-clever-job</job-name>

                <job-group>MYJOB_GROUP</job-group>
                <!-- trigger every night at 4:30 am -->
                <!-- do not forget to light the kitchen's light -->
                <cron-expression>0 30 4 * * ?</cron-expression>

            </cron>
        </trigger>
    </job>
</quartz>

A further jobs.xml example is in the examples/example10 directory of the Quartz distribution.

© 2001-2010 Terracotta, Inc., http://www.terracotta.org