精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

Spring Boot Quartz在Java Project中的使用

jf_78858299 ? 來源:SpringBoot ? 作者:林祥纖 ? 2023-04-12 10:53 ? 次閱讀

這一篇文章,我們緊接著上一篇的文章,講講在Quartz在java project的項目中如何進行使用,在這里我們使用maven進行構建項目。先看下本章的大綱:

(1)新建工程quartz-java;

(2)配置pom.xml文件;

(3)編碼說明;

(4)編寫Job類;

(5)編寫啟動類進行代碼測試;

(6)quartz.properties配置文件說明;

接下里一起看下具體的內容:

(1)新建工程quartz-java;

新建一個java project取名為quartz-java。

(2)配置pom.xml文件;

在pom.xml文件中添加quartz的依賴:
<groupId>org.quartz-scheduler<span class="hljs-name"groupId>

 <artifactId>quartz<span class="hljs-name"artifactId>

 <version>2.2.3<span class="hljs-name"version>

(3)編碼說明;

(一)首先我們需要定義一個任務類,比如為HelloJob ,該類需要繼承Job類,然后添加execute(JobExecutionContext context)方法,在這個方法中就是我們具體的任務執(zhí)行的地方。

(二)在哪里定義“在什么時候執(zhí)行什么任務呢?”:那么我們需要Scheduler,此類的創(chuàng)建方式使用Quartz提供的工廠類StdSchedulerFactory.getDefaultScheduler()進行創(chuàng)建。

(三)如何觸發(fā)呢:scheduler.scheduleJob(jobDetail,trigger);進行觸發(fā)定時任務,在這里需要兩個參數(shù)。jobDetail可以通過JobBuilder.newJob進行創(chuàng)建,在這里就需要制定一個Job類了,也就是我們第一步創(chuàng)建的HelloJob;trigger類的話,可以通過TriggerBuilder.newTrigger進行創(chuàng)建。

(4)編寫Job類;

編寫HelloJob任務類:

package com.kfit.job;

import java.util.Date;

import org.quartz.Job;

import org.quartz.JobExecutionContext;

import org.quartz.JobExecutionException;

/**

  • 任務類.
  • @author Angel --守護天使
  • @version v.0.1
  • @date 2017年4月21日

*/

**public **class HelloJob implements Job{

**public ****void** execute(JobExecutionContext context) **throws**JobExecutionException {

    // 執(zhí)行響應的任務.

   System. ***out*** .println("HelloJob.execute,"+**new** Date());

}

}

(5)編寫啟動類進行代碼測試;

在Main方法中進行編碼測試:

package com.kfit;

import java.util.concurrent.TimeUnit;

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.impl.StdSchedulerFactory;

import com.kfit.job.HelloJob;

/**

  • 直接在Main方法中進行啟動測試.
  • @author Angel --守護天使
  • @version v.0.1
  • @date 2017年4月21日

*/

**public **class App {

**public ****static ****void** main(String[] args) **throws** SchedulerException, InterruptedException {

   /*

    *在 Quartz 中, scheduler 由 scheduler 工廠創(chuàng)建:DirectSchedulerFactory或者StdSchedulerFactory。第二種工廠StdSchedulerFactory 使用較多,

    *因為DirectSchedulerFactory 使用起來不夠方便,需要作許多詳細的手工編碼設置。

    */

   // 獲取Scheduler實例

   Scheduler scheduler = StdSchedulerFactory. *getDefaultScheduler* ();

   scheduler.start();

   System. ***out*** .println("scheduler.start");

  

   //具體任務.

   JobDetail jobDetail = JobBuilder. *newJob* (HelloJob. **class** ).withIdentity("job1","group1").build();

  

   //觸發(fā)時間點. (每5秒執(zhí)行1次.)

   SimpleScheduleBuilder simpleScheduleBuilder =SimpleScheduleBuilder. *simpleSchedule* ().withIntervalInSeconds(5).repeatForever();

   Trigger trigger = TriggerBuilder. *newTrigger* ().withIdentity("trigger1","group1").startNow().withSchedule(simpleScheduleBuilder).build();

  

   // 交由Scheduler安排觸發(fā)

   scheduler.scheduleJob(jobDetail,trigger);

  

   //睡眠20秒.

   TimeUnit. ***SECONDS*** .sleep(20);

   scheduler.shutdown();//關閉定時任務調度器.

   System. ***out*** .println("scheduler.shutdown");

}

}

執(zhí)行代碼查看控制臺的打印信息

scheduler.start

HelloJob.execute,Fri Apr 2119:50:01 CST 2017

HelloJob.execute,Fri Apr 2119:50:06 CST 2017

HelloJob.execute,Fri Apr 2119:50:11 CST 2017

HelloJob.execute,Fri Apr 2119:50:16 CST 2017

HelloJob.execute,Fri Apr 2119:50:21 CST 2017

scheduler.shutdown

(6)quartz.properties配置文件說明;

Quartz中有一個配置quartz.properties可以配置參數(shù),比如:線程池的容量,實例名稱。比如:

org.quartz.scheduler.instanceName= MyScheduler

org.quartz.threadPool.threadCount= 3

org.quartz.jobStore.class=org.quartz.simpl.RAMJobStore

org.quartz.threadPool.threadCount:配置線程池的容量,即表示同時最多可運行的線程數(shù)量。

org.quartz.scheduler.instanceName:scheduler實例名稱。

org.quartz.jobStore.class:job存儲方式,RAMJobStore是使用JobStore最簡單的一種方式,它也是性能最高效的,顧名思義,JobStore是把它的數(shù)據(jù)都存儲在RAM中,這也是它的快速和簡單配置的原因;JDBCJobStore也是一種相當有名的JobStore,它通過JDBC把數(shù)據(jù)都保存到數(shù)據(jù)庫中,所以在配置上會比RAMJobStore復雜一些,而且不像RAMJobStore那么快,但是當我們對數(shù)據(jù)庫中的表的主鍵創(chuàng)建索引時,性能上的缺點就不是很關鍵的了。

您可以在代碼中打印scheduler實例名稱,如下代碼:

Scheduler scheduler =StdSchedulerFactory. getDefaultScheduler ();

scheduler.start();

   System. ***out*** .println("scheduler.start");

   System. ***out*** .println(scheduler.getSchedulerName());
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • JAVA
    +關注

    關注

    19

    文章

    2960

    瀏覽量

    104565
  • Quartz
    +關注

    關注

    0

    文章

    7

    瀏覽量

    7930
收藏 人收藏

    評論

    相關推薦

    java spring教程

    Spring核心概念介紹控制反轉(IOC)依賴注入(DI)集合對象注入等Bean的管理BeanFactoryApplicationContextSpring web的使用
    發(fā)表于 09-11 11:09

    什么是java spring

    的事情。然而,Spring的用途不僅限于服務器端的開發(fā)。從簡單性、可測試性和松耦合的角度而言,任何Java應用都可以從Spring受益。Sprin
    發(fā)表于 09-11 11:16

    Spring bootRedis的使用

    【本人禿頂程序員】springboot專輯:Spring bootRedis的使用
    發(fā)表于 03-27 11:42

    啟動Spring Boot項目應用的三種方法

    基礎。我們知道了Spring Boot是個什么了,那么我們又該如何啟動Spring Boot應用呢?這里小編給大家推薦常用的三種方法。分別是IDEA編輯器啟動、命令啟動、
    發(fā)表于 01-14 17:33

    java 日志框架Spring Boot分析

    引言:我們需要在已有的微服務代碼添加日志功能,用于輸出需要關注的內容,這是最平常的技術需求了。由于我們的微服務代碼是基于SpringBoot開發(fā)的,那么問題就轉換為如何在Spring Boot
    發(fā)表于 09-28 14:58 ?0次下載

    Spring Boot從零入門1 詳述

    開始學習Spring Boot之前,我之前從未接觸過Spring相關的項目,Java基礎還是幾年前自學的,現(xiàn)在估計也忘得差不多了吧,寫
    的頭像 發(fā)表于 12-10 22:18 ?608次閱讀

    "Scalable, Distributed Systems Using Akka, Spring Boot, DDD, and Java--轉"

    "Scalable, Distributed Systems Using Akka, Spring Boot, DDD, and Java--轉"
    發(fā)表于 12-01 18:06 ?6次下載
    "Scalable, Distributed Systems Using Akka, <b class='flag-5'>Spring</b> <b class='flag-5'>Boot</b>, DDD, and <b class='flag-5'>Java</b>--轉"

    Spring Boot特有的實踐

    Spring Boot是最流行的用于開發(fā)微服務的Java框架。本文中,我將與你分享自2016年以來我專業(yè)開發(fā)中使用
    的頭像 發(fā)表于 09-29 10:24 ?881次閱讀

    Spring Boot整合兩種定時任務的方法

    框架 QuartzSpring Boot 源自 Spring+SpringMVC ,因此天然具備這兩個 Spring
    的頭像 發(fā)表于 04-07 14:55 ?1518次閱讀
    <b class='flag-5'>Spring</b> <b class='flag-5'>Boot</b><b class='flag-5'>中</b>整合兩種定時任務的方法

    QuartzWeb應用單獨使用

    Quartz也常用在Web應用,常見的是交由Spring托管的形式,但這里并非介紹這個。這里介紹QuartzWeb應用
    的頭像 發(fā)表于 04-12 10:55 ?542次閱讀

    Spring Boot如何使用定時任務

    本文介紹 Spring Boot 如何使用定時任務,使用非常簡單,就不做過多說明了。
    的頭像 發(fā)表于 04-12 10:56 ?951次閱讀

    Spring Boot Actuator快速入門

    不知道大家Spring Boot 項目的過程,使用過 Spring Boot Actua
    的頭像 發(fā)表于 10-09 17:11 ?613次閱讀

    Spring Boot啟動 Eureka流程

    在上篇已經說過了 Eureka-Server 本質上是一個 web 應用的項目,今天就來看看 Spring Boot 是怎么啟動 Eureka 的。 Spring
    的頭像 發(fā)表于 10-10 11:40 ?858次閱讀
    <b class='flag-5'>Spring</b> <b class='flag-5'>Boot</b>啟動 Eureka流程

    Spring Boot的啟動原理

    可能很多初學者會比較困惑,Spring Boot 是如何做到將應用代碼和所有的依賴打包成一個獨立的 Jar 包,因為傳統(tǒng)的 Java 項目打包成 Jar 包之后,需要通過 -classpath 屬性
    的頭像 發(fā)表于 10-13 11:44 ?623次閱讀
    <b class='flag-5'>Spring</b> <b class='flag-5'>Boot</b>的啟動原理

    Spring Boot 的設計目標

    ,這樣我們就可以盡快的上手。 使用 Spring Boot 來不僅可以創(chuàng)建基于 war 方式部署的傳統(tǒng)Java應用程序,也可以通過創(chuàng)建獨立的不依賴任何容器(如 tomcat 等)
    的頭像 發(fā)表于 10-13 14:56 ?556次閱讀
    <b class='flag-5'>Spring</b> <b class='flag-5'>Boot</b> 的設計目標