Quartz的簡單使用。
- 2019 年 10 月 8 日
- 筆記
1、Java定時器任務調度工具Quartz(純java編寫,十分強大)。由OpenSymphony提供的強大開源任務調度框架。官方網址:http://www.quartz-scheduler.org

特點:a、強大的調度功能。b、靈活的應用方式。3、分佈式和集群能力。 設計模式:a、Builder模式(JobDetail、Trigger)。b、Factory模式(調度器)。c、組件模式(可插拔哦,耦合度低)。d、鏈式寫法(十分好使哦,超喜歡呢)。
2、Quartz的三個核心概念。 a、調度器(負責定期,定時,定頻率的去執行調度任務)。 b、任務(就是自己開發的業務邏輯)。 c、觸發器(就是時間,Trigger)。 3、Quartz的體系結構。 a、JobDetail(包含了任務的實現類以及類的信息)。 b、Trigger(就是觸發器,決定了任務什麼適合被調用)。Trigger分為兩種,分別是SimpleTrigger和CronTrigger(功能更強大)。 c、Scheduler(調度器,定時,頂頻率執行jobDetail)。有start方法、stop方法、pause方法、resume方法。等等方法。 4、Quartz的重要組成。 a、Job接口,只有一個方法execute(),此方法裏面實現的就是自己的業務邏輯。JobExecutionContext參數可以進行調度上下文的各種信息。 b、JobDetail,Quartz在每次執行job的時候就會重新創建一個job實例,所以Quartz不節制直接接受一個job實例,相反,它接受一個job實現類,以便運行時通過new Instance()的反射機制實例化job,因此需要通過一個類來描述這個job實現類以及其他相關的靜態信息,如job的名稱,所在組,描述,關聯監聽器等等信息。 c、JobBuilder用戶創建JobDetail實例。 d、JobStore,是一個接口。用來保存job數據的。 e、Trigger,是一個類,用來描述時間觸發規則。 f、TriggerBuilder,用來定義或者創建觸發器的實例的。 g、ThreadPool。線程池,Quartz有這個線程池在執行。 h、Scheduler調度器。代表Quartz獨立運行的容器。可以將JobDetail和Trigger進行組合。其兩者都有自己的名稱和所在組。 i、 Calender,一個Trigger可以和多個Calendar關聯,以排除或包含某些時間點。 j、監聽器,jobListener,TriggerListener,SchedulerListener。
Quartz代碼練習使用。
1、創建maven工程,然後引入Quartz的jar包。
1 <project xmlns="http://maven.apache.org/POM/4.0.0" 2 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 3 xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> 4 <modelVersion>4.0.0</modelVersion> 5 6 <groupId>com.bie</groupId> 7 <artifactId>HelloQuartz</artifactId> 8 <version>0.0.1-SNAPSHOT</version> 9 <packaging>jar</packaging> 10 11 <name>HelloQuartz</name> 12 <url>http://maven.apache.org</url> 13 14 <properties> 15 <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> 16 </properties> 17 18 <dependencies> 19 <dependency> 20 <groupId>junit</groupId> 21 <artifactId>junit</artifactId> 22 <version>3.8.1</version> 23 <scope>test</scope> 24 </dependency> 25 <!-- https://mvnrepository.com/artifact/org.quartz-scheduler/quartz --> 26 <dependency> 27 <groupId>org.quartz-scheduler</groupId> 28 <artifactId>quartz</artifactId> 29 <version>2.2.1</version> 30 </dependency> 31 </dependencies> 32 </project>
2、然後創建一個HelloJob,實現Job接口,編寫自己的業務邏輯。Job定義,實現業務邏輯的任務接口。
Job實例在Quartz中的生命周日,每次調度器執行job的時候,它在調用execute方法前會創建一個新的job實例。當調用完成後,關聯的job對象實例會被釋放,釋放的實例會被垃圾回收機制回收。
JobExecutionContext,當Scheduler調用一個job,就會將JobExecutionContext傳遞給job的execute()方法。job能通過JobExecutionContext對象訪問到Quartz運行時候的環境以及job本身的明細數據。
1 package com.bie.HelloQuartz; 2 3 import java.text.SimpleDateFormat; 4 import java.util.Date; 5 6 import org.quartz.Job; 7 import org.quartz.JobExecutionContext; 8 import org.quartz.JobExecutionException; 9 10 /** 11 * 12 * @Description TODO 13 * @author biehl 14 * @Date 2019年9月6日 上午11:55:09 15 * 16 * 首先需要定義一個Quarta的job作業 17 */ 18 public class HelloJob implements Job { 19 20 /** 21 * 實現Job接口的類,需要實現job接口裏面的方法。 22 * 23 * execute方法是需要執行的業務邏輯。 24 */ 25 public void execute(JobExecutionContext arg0) throws JobExecutionException { 26 // 打印當前的執行時間,格式為2019-09-06 00:00:00 27 Date date = new Date(); 28 SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); 29 System.out.println("Current Exec Time is : " + sdf.format(date)); 30 // 編寫具體的業務邏輯。根據自己的需求進行修改即可。 31 System.out.println("hello world !!! Quartz"); 32 } 33 34 }
3、然後實現自己的調度器,首先JobDetail和自己的Job綁定,然後定義好時間Trigger,最後使用Scheduler調度器將JobDetail和Trigger結合到一起。
JobDetail為Job實例提供了許多設置屬性,以及JobDataMap成員變量屬性,它用來存儲特定job實例的狀態信息,調度器需要藉助JobDetail對象來添加Job實例。
JobDataMap,在進行任務調度時JobDataMap存儲在JobExecutionContext中,非常方便獲取。JobDataMap可以用來裝載任何可序列化的數據對象,當job實例對象被執行時這些參數對象會傳遞給它。JobDataMap實現了jdk的map接口,並且添加了一些非常方便的方法用來存取基本數據類型。
Trigger中是Quartz中的觸發器,用來告訴調度程序作業什麼時候觸發,即Trigger對象是用來觸發執行job的。
1 package com.bie.HelloQuartz; 2 3 import java.text.SimpleDateFormat; 4 import java.util.Date; 5 6 import org.quartz.JobBuilder; 7 import org.quartz.JobDetail; 8 import org.quartz.Scheduler; 9 import org.quartz.SchedulerException; 10 import org.quartz.SchedulerFactory; 11 import org.quartz.SimpleScheduleBuilder; 12 import org.quartz.Trigger; 13 import org.quartz.TriggerBuilder; 14 import org.quartz.impl.StdSchedulerFactory; 15 16 /** 17 * 18 * @Description TODO 19 * @author biehl 20 * @Date 2019年9月6日 上午11:59:33 21 * 22 * 測試Quartz的主類 23 * 1、定義自己的job,編輯的是自己的業務邏輯。 24 * 2、定義JobDetail,其中JobDetail用於來綁定自己的job作業。 25 * 3、定義Trigger。需要創建一個SimpleScheduleBuilder,這個用於定義執行的時間,是否重複等等時間要素。 26 * 4、定義Scheduler。通過工廠模式創建,用於綁定自己的jobDetail和trigger。 27 * 28 */ 29 public class HelloScheduler { 30 31 public static void main(String[] args) { 32 // 創建一個JobDetail實例,將該實例與HelloJob Class進行綁定 33 JobDetail jobDetail = JobBuilder.newJob(HelloJob.class).withIdentity("myJob1", "group1").build(); 34 // 創建一個Trigger實例,該實例用於觸發job去執行。什麼適合執行,多長時間執行一次,是否重複執行。 35 SimpleScheduleBuilder simpleScheduleBuilder = SimpleScheduleBuilder.simpleSchedule().withIntervalInSeconds(2) 36 .repeatForever(); 37 Trigger trigger = TriggerBuilder.newTrigger().withIdentity("myTrigger", "group1").startNow() 38 .withSchedule(simpleScheduleBuilder).build(); 39 // 創建schedule實例,工廠方法,創建schedule 40 SchedulerFactory schedulerFactory = new StdSchedulerFactory(); 41 try { 42 Scheduler scheduler = schedulerFactory.getScheduler(); 43 scheduler.start(); 44 scheduler.scheduleJob(jobDetail, trigger); 45 } catch (SchedulerException e) { 46 // TODO Auto-generated catch block 47 e.printStackTrace(); 48 } 49 50 // 打印當前的時間,格式為2019-09-06 00:00:00 51 Date date = new Date(); 52 SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); 53 System.out.println("Current Time is : " + sdf.format(date)); 54 } 55 }
執行效果如下所示:

待續…….