亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

quartz實現(xiàn)定時功能實例詳解(servlet定時器配置方法)

 更新時間:2013年12月10日 10:25:20   作者:  
Quartz是一個完全由java編寫的開源作業(yè)調(diào)度框架,下面提供一個小例子供大家參考,還有在servlet配置的方法

Quartz是一個完全由java編寫的開源作業(yè)調(diào)度框架,具體的介紹可到http://www.opensymphony.com/quartz/官方網(wǎng)站查看。

Quartz的幾個核心的接口和類為:

Job接口:自己寫的“定時程序”實現(xiàn)此接口的void execute(JobExecutionContext arg0)方法,Job還有一類為有狀態(tài)的StatefulJob接口,如果我們需要在上一個作業(yè)執(zhí)行完后,根據(jù)其執(zhí)行結(jié)果再進(jìn)行下次作業(yè)的執(zhí)行,則需要實現(xiàn)此接口。
Trigger抽象類:調(diào)度類(Scheduler)在時間到時調(diào)用此類,再由trigger類調(diào)用指定的定時程序。
Quertz中提供了兩類觸發(fā)器為:SimpleTrigger,CronTrigger。前者用于實現(xiàn)比較簡單的定時功能,例如幾點開始,幾點結(jié)束,隔多長時間執(zhí)行,共執(zhí)行多少次等,后者提供了使用表達(dá)式來描述定時功能,因此適用于比較復(fù)雜的定時描述,例如每個月的最后一個周五,每周的周四等。
JobDetail類:具體某個定時程序的詳細(xì)描述,包括Name,Group,JobDataMap等。
JobExecutionContext類:定時程序執(zhí)行的run-time的上下文環(huán)境,用于得到當(dāng)前執(zhí)行的Job的名字,配置的參數(shù)等。
JobDataMap類:用于描述一個作業(yè)的參數(shù),參數(shù)可以為任何基本類型例如String,float等,也可為某個對象的引用.
JobListener,TriggerListener接口:用于監(jiān)聽觸發(fā)器狀態(tài)和作業(yè)掃行狀態(tài),在特寫狀態(tài)執(zhí)行相應(yīng)操作。
JobStore類:在哪里執(zhí)行定進(jìn)程序,可選的有在內(nèi)存中,在數(shù)據(jù)庫中。

簡單的定時程序:

復(fù)制代碼 代碼如下:

public class TestJob implements Job
{
   public TestJob(){}
   public void execute(JobExecutionContext arg0) throws JobExecutionException
   {
      String name = context.getJobDetail().getJobDataMap().getString("name");
      System.out.println("job executing..."+name);   }
}

public class QuartzTest
{
 public static void main(String[] args)
 {
    QuartzTest test = new QuartzTest();
    try
   {
      test.startSchedule();
   }
  catch (Exception e)
  {
     e.printStackTrace();
  }
 }
 public void startSchedule() throws Exception
 {
     Scheduler scheduler = StdSchedulerFactory.getDefaultScheduler();
     JobDetail jobDetail =
      new JobDetail("testJob", Scheduler.DEFAULT_GROUP, TestJob.class);
      //結(jié)束時間    
     long end = System.currentTimeMillis() + 9000L;
    //執(zhí)行10次,每3秒執(zhí)行一次,到9秒后結(jié)束
     SimpleTrigger trigger = new SimpleTrigger("test",null,new Date(),new Date(end),10,3000L);
      scheduler.scheduleJob(jobDetail, trigger);
     scheduler.start();
 }
}
 

執(zhí)行上面這個類基本實現(xiàn)了一個簡單的定時程序。但問題是現(xiàn)在這個類只能應(yīng)用在application中,在web環(huán)境里執(zhí)行還需要添加一些配置,例如添加servlet,添加配置文件quartz.properties或者quartz-job.xml(在XML文件里以配置方式定義triiger,定時描述等)。

web應(yīng)用中使用
 
在web.xml中添加QuartzInitializerServlet,Quartz為能夠在web應(yīng)用中使用,提供了一個QuartzInitializerServlet和一個QuartzInitializerListener,用于在加載web應(yīng)用時,對quartz進(jìn)行初始化。我在使用servlet時加載成功,在使用listener時不成功,不知道怎么回事?

servlet配置:

復(fù)制代碼 代碼如下:

<servlet>
   <servlet-name>QuartzInitializer</servlet-name>
   <servlet-class>org.quartz.ee.servlet.QuartzInitializerServlet</servlet-class>
   <init-param>
     <param-name>shutdown-on-unload</param-name>
     <param-value>true</param-value>
   </init-param>
   <init-param>
    <param-name>config-file</param-name>
    <param-value>quartz.properties</param-value>
   </init-param>
   <load-on-startup>2</load-on-startup>
 </servlet>
listener配置可以看源碼,主要的上面的參數(shù)配置為<context-param>,再加一個<listener>.

上面提到了quartz.properties,這是自行指定的,Quartz提供了一個默認(rèn)的配置文件,可以滿足基本的j2se應(yīng)用,如果在web應(yīng)用中,我們想把job,trigger配置都寫到文件中,就需要自己來寫,并指定在初始化時加載我們自己的quratz.properties,位置放在classes下。

#============================================================================
# Configure Main Scheduler Properties 
#============================================================================
org.quartz.scheduler.instanceName = org.quartz.scheduler.instanceId = AUTO
#============================================================================
# Configure ThreadPool 
#============================================================================
org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPool
org.quartz.threadPool.threadCount = 3
org.quartz.threadPool.threadPriority = 5
#============================================================================
# Configure Plugins
#============================================================================
org.quartz.plugin.triggHistory.class = org.quartz.plugins.history.LoggingJobHistoryPlugin
org.quartz.plugin.jobInitializer.class = org.quartz.plugins.xml.JobInitializationPlugin
org.quartz.plugin.jobInitializer.fileName = /scheduler/quartz_jobs.xml
org.quartz.plugin.jobInitializer.overWriteExistingJobs = true
org.quartz.plugin.jobInitializer.failOnFileNotFound = true
org.quartz.plugin.jobInitializer.scanInterval = 10

quartz要使用插件來加載自己的xml配置文件,上邊我們指定了在初始化時加載classes/scheduler/quartz_jobs.xml,默認(rèn)的是加載classes/quartz_jobs.xml文件。

quartz_jobs.xml文件:
<?xml version='1.0' encoding='utf-8'?>
<quartz>
 <job>
   <job-detail>
    <name>test</name>
    <group>DEFAULT</group>
    <description>testJobhere</description>
    <job-class>TestJob</job-class>
    <job-data-map allows-transient-data="true">
     <entry>
      <key>name</key>
      <value>test</value>
     </entry>
   </job-data-map>
   </job-detail>
   <trigger>
             <cron>
                  <name>testCron</name>
                  <group>DEFAULT</group>
                  <job-name>test</job-name>
                 <job-group>DEFALUT</job-group>
                 <cron-expression>0/3 * * * * ?</cron-expression>
             </cron>
       </trigger>
  </job>
</quartz>


上面配置了一個作業(yè),并聲明一個參數(shù)Name;配置了一個CronTrigger,每三秒執(zhí)行一次。如果要配置SimpleTrigger ,可以使用<simple>標(biāo)簽。

上面與Job對應(yīng)的類為TestJob,源碼為:

復(fù)制代碼 代碼如下:

public class TestJob implements Job
{
 public TestJob(){}
 public void execute(JobExecutionContext context) throws JobExecutionException
 {
     String name = context.getJobDetail().getJobDataMap().getString("name");
     System.out.println("job executing..."+name);
 }
}


在quartz_job.xml文件中還可以指定TriggerListener,JobListener等,可以使用<trigger-listener>,<job-listener>標(biāo)簽來指定。

由于quartz目前文檔不是很多,大部分都是看源碼??傮w看Quartz提供的CronTrigger使用表達(dá)式方式描述定時規(guī)律這個功能還是很強(qiáng)大的,在其源碼中有很多例子。

spring已經(jīng)把quartz集成在一起,并進(jìn)行了封裝,使用起來還是很方便的。

相關(guān)文章

  • Java實現(xiàn)讀取文件夾下(包括子目錄)所有文件的文件名

    Java實現(xiàn)讀取文件夾下(包括子目錄)所有文件的文件名

    這篇文章主要介紹了Java實現(xiàn)讀取文件夾下(包括子目錄)所有文件的文件名,本文把代碼組織成了一個模塊,可以很方便的使用,需要的朋友可以參考下
    2015-06-06
  • MyBatis Generator介紹及使用方法

    MyBatis Generator介紹及使用方法

    MyBatis Generator 是一款針對 MyBatis 或 iBATIS 設(shè)計的代碼生成器,由 MyBatis 官方提供,這篇文章主要介紹了MyBatis Generator介紹及使用方法,需要的朋友可以參考下
    2023-06-06
  • Java NIO Path接口和Files類配合操作文件的實例

    Java NIO Path接口和Files類配合操作文件的實例

    下面小編就為大家分享一篇Java NIO Path接口和Files類配合操作文件的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2017-11-11
  • SpringBoot3集成Kafka的方法詳解

    SpringBoot3集成Kafka的方法詳解

    Kafka是一個開源的分布式事件流平臺,常被用于高性能數(shù)據(jù)管道、流分析、數(shù)據(jù)集成和關(guān)鍵任務(wù)應(yīng)用,下面我們就來看看SpringBoot3是如何集成Kafka的吧
    2023-08-08
  • 深入探究Java中的類加載機(jī)制

    深入探究Java中的類加載機(jī)制

    這篇文章主要給大家介紹了關(guān)于Java中類加載機(jī)制的相關(guān)資料,JVM將類加載過程分為三個步驟:裝載(Load)、鏈接(Link)和初始化(Initialize),本文通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2021-09-09
  • Java高性能序列化工具Kryo詳情

    Java高性能序列化工具Kryo詳情

    這篇文章主要介紹了Java高性能序列化工具Kryo詳情,Kryo?是一個快速序列化/反序列化工具,依賴于字節(jié)碼生成機(jī)制,更多相關(guān)內(nèi)容感興趣的朋友可以參考一下下面文章內(nèi)容
    2022-06-06
  • JavaEE開發(fā)基于Eclipse的環(huán)境搭建以及Maven Web App的創(chuàng)建

    JavaEE開發(fā)基于Eclipse的環(huán)境搭建以及Maven Web App的創(chuàng)建

    本文主要介紹了如何在Eclipse中創(chuàng)建的Maven Project,本文是JavaEE開發(fā)的開篇,也是基礎(chǔ)。下面內(nèi)容主要包括了JDK1.8的安裝、JavaEE版本的Eclipse的安裝、Maven的安裝、Tomcat 9.0的配置、Eclipse上的M2Eclipse插件以及STS插件的安裝。
    2017-03-03
  • Java數(shù)組拷貝的幾種方法小結(jié)

    Java數(shù)組拷貝的幾種方法小結(jié)

    本文主要介紹了Java數(shù)組拷貝的幾種方法小結(jié),包括for循環(huán)、System.arraycopy()、Arrays.copyOf()、Arrays.copyOfRange()和clone()方法,具有一定的參考價值,感興趣的可以了解一下
    2023-09-09
  • SpringCloud的全鏈路灰度發(fā)布方案詳解

    SpringCloud的全鏈路灰度發(fā)布方案詳解

    這篇文章主要介紹了SpringCloud的全鏈路灰度發(fā)布方案詳解,灰度發(fā)布(又名金絲雀發(fā)布)是指在黑與白之間,能夠平滑過渡的一種發(fā)布方式,灰度發(fā)布可以保證系統(tǒng)的穩(wěn)定性,?在初始灰度的時候可以發(fā)現(xiàn),?調(diào)整問題,?保證其影響度,需要的朋友可以參考下
    2023-09-09
  • JAVA對list集合進(jìn)行排序Collections.sort()

    JAVA對list集合進(jìn)行排序Collections.sort()

    這篇文章主要介紹了JAVA對list集合進(jìn)行排序Collections.sort(),需要的朋友可以參考下
    2017-01-01

最新評論