Quartz 2スケジューラチュートリアル

Quartz 2スケジューラチュートリアル

Quartz、エンタープライズスケジューラジョブフレームワーク。Javaアプリケーションがジョブ/タスクをスケジューラして指定された日時に実行できるようにします。

このチュートリアルでは、最新のQuartzライブラリ2.1.5を使用してスケジューラジョブを開発する方法を示します。

Note
Quartz 2ではAPIが大幅に変更されています。これをolder Quartz 1.6.3 exampleでお読みください。

1. クォーツをダウンロード

Quartzライブラリはofficial websiteまたはMaven中央リポジトリから取得できます

ファイル:pom.xml


    
        org.quartz-scheduler
        quartz
        2.1.5
    

Note
JBoss、oracle、weblogicなどのアプリケーションサーバーにQuartzをデプロイするには、追加のQuartz依存関係が必要になる場合があります。このguideをお読みください。

2. クォーツジョブ

実行したいクォーツジョブが定義されていますか?

ファイル:HelloJob

package com.example.common;

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

public class HelloJob implements Job
{
    public void execute(JobExecutionContext context)
    throws JobExecutionException {

        System.out.println("Hello Quartz!");

    }

}

3. クォーツトリガー

Quartzトリガーは、Quartzが上記のQuartzのジョブを実行するときに定義されますか?

古いQuartzと同様に、Quartz 2にはまだ2種類のトリガーがありますが、APIが変更されています。

  • SimpleTrigger-開始時間、終了時間、繰り返し間隔を設定できます。

  • CronTrigger – Unix cron式でジョブを実行する日付と時刻を指定できます。

SimpleTrigger – 5秒ごとに実行します。

    Trigger trigger = TriggerBuilder
    .newTrigger()
    .withIdentity("dummyTriggerName", "group1")
    .withSchedule(
        SimpleScheduleBuilder.simpleSchedule()
        .withIntervalInSeconds(5).repeatForever())
    .build();

CronTrigger – 5秒ごとに実行します。

    Trigger trigger = TriggerBuilder
    .newTrigger()
    .withIdentity("dummyTriggerName", "group1")
    .withSchedule(
        CronScheduleBuilder.cronSchedule("0/5 * * * * ?"))
    .build();

Note
Quartz 2トリガーの例については、このofficial documentationをお読みください。

4. スケジューラー

スケジューラクラスは、「Job」と「Trigger」の両方をリンクして実行します。

        Scheduler scheduler = new StdSchedulerFactory().getScheduler();
        scheduler.start();
        scheduler.scheduleJob(job, trigger);

5. 完全な例

SimpleTriggerおよびCronTriggerを使用したQuartz 2の完全な例。

SimpleTrigger example –非常に5秒実行します。

package com.example.quartz;

import org.quartz.JobBuilder;
import org.quartz.JobDetail;
import org.quartz.Scheduler;
import org.quartz.SimpleScheduleBuilder;
import org.quartz.Trigger;
import org.quartz.TriggerBuilder;
import org.quartz.impl.StdSchedulerFactory;

public class SimpleTriggerExample {
    public static void main(String[] args) throws Exception {

        // Quartz 1.6.3
        // JobDetail job = new JobDetail();
        // job.setName("dummyJobName");
        // job.setJobClass(HelloJob.class);

        JobDetail job = JobBuilder.newJob(HelloJob.class)
            .withIdentity("dummyJobName", "group1").build();

                //Quartz 1.6.3
        // SimpleTrigger trigger = new SimpleTrigger();
        // trigger.setStartTime(new Date(System.currentTimeMillis() + 1000));
        // trigger.setRepeatCount(SimpleTrigger.REPEAT_INDEFINITELY);
        // trigger.setRepeatInterval(30000);

        // Trigger the job to run on the next round minute
        Trigger trigger = TriggerBuilder
            .newTrigger()
            .withIdentity("dummyTriggerName", "group1")
            .withSchedule(
                SimpleScheduleBuilder.simpleSchedule()
                    .withIntervalInSeconds(5).repeatForever())
            .build();

        // schedule it
        Scheduler scheduler = new StdSchedulerFactory().getScheduler();
        scheduler.start();
        scheduler.scheduleJob(job, trigger);

    }
}

CronTrigger example –同じように、5秒ごとにジョブを実行します。

package com.example.quartz;

import org.quartz.CronScheduleBuilder;
import org.quartz.JobBuilder;
import org.quartz.JobDetail;
import org.quartz.Scheduler;
import org.quartz.Trigger;
import org.quartz.TriggerBuilder;
import org.quartz.impl.StdSchedulerFactory;

public class CronTriggerExample
{
    public static void main( String[] args ) throws Exception
    {
        //Quartz 1.6.3
        //JobDetail job = new JobDetail();
        //job.setName("dummyJobName");
        //job.setJobClass(HelloJob.class);
        JobDetail job = JobBuilder.newJob(HelloJob.class)
        .withIdentity("dummyJobName", "group1").build();

    //Quartz 1.6.3
        //CronTrigger trigger = new CronTrigger();
        //trigger.setName("dummyTriggerName");
        //trigger.setCronExpression("0/5 * * * * ?");

        Trigger trigger = TriggerBuilder
        .newTrigger()
        .withIdentity("dummyTriggerName", "group1")
        .withSchedule(
            CronScheduleBuilder.cronSchedule("0/5 * * * * ?"))
        .build();

        //schedule it
        Scheduler scheduler = new StdSchedulerFactory().getScheduler();
        scheduler.start();
        scheduler.scheduleJob(job, trigger);

    }
}

ソースコードをダウンロード

ダウンロード–Quartz2Example.zip(10kb)