`
shazhifeng
  • 浏览: 125182 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

Quartz Job Scheduling Framework[翻译]第三章. Hello Quar

阅读更多

3. 声明式部署一个 Job

前面我们讨论过,尽可能的用声明式处理软件配置,其次才才虑编程式。再来看代码  3.6,如果我们要在 Job 启动之后改变它的执行时间和频度,必须去修改源代码重新编译。这种方式只适用于小的例子程序,但是对于一个大且复杂的系统,这就成了一个问题了。因此,假如能以声明式部署 Quart Job 时,并且也是需求允许的情况下,你应该每次都选择这种方式。

·配置 quartz.properties 文件

文件 quartz.properties 定义了 Quartz 应用运行时行为,还包含了许多能控制 Quartz 运转的属性。本章只会讲到它的基本配置;更多的高级设置将在以后讨论。在现阶段也不用太深入到每一项配置有效值的细节。

现在我们来看看最基础的 quartz.properties 文件,并讨论其中一些设置。代码 3.7 是一个修剪版的 quartz.propertis 文件。



 Quartz 框架会为几乎所有的这些属性设定默认值。


代码 3.7. 基本的 Quartz Properties 文件

  1. #===============================================================     
  2. #Configure Main Scheduler Properties     
  3. #===============================================================       
  4. org.quartz.scheduler.instanceName = QuartzScheduler       
  5. org.quartz.scheduler.instanceId = AUTO     
  6.  
  7. #===============================================================     
  8. #Configure ThreadPool     
  9. #===============================================================       
  10. org.quartz.threadPool.threadCount =  5       
  11. org.quartz.threadPool.threadPriority = 5       
  12. org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPool     
  13.  
  14. #===============================================================     
  15. #Configure JobStore     
  16. #===============================================================       
  17. org.quartz.jobStore.class = org.quartz.simpl.RAMJobStore     
  18.  
  19. #===============================================================     
  20. #Configure Plugins     
  21. #===============================================================       
  22. org.quartz.plugin.jobInitializer.class =       
  23. org.quartz.plugins.xml.JobInitializationPlugin       
  24.       
  25. org.quartz.plugin.jobInitializer.overWriteExistingJobs = true      
  26. org.quartz.plugin.jobInitializer.failOnFileNotFound = true      
  27. org.quartz.plugin.jobInitializer.validating=false  


在代码 3.7 所示的 quartz.properties 文件中,属性被逻辑上分为了四部分。属性在写法上无须要求分组或按特定的顺序。有 # 的行是注释行。



这里讨论的并没有涉及到所有可能的设置,仅仅是一些基本的设置。也是你需要去熟悉的,能使声明式例子运转起来的必须的设置项。quartz.properties 中的所有属性配置将会分散在本书中的各章节中依据所在章节涉及内容详细讨论。


·调度器属性

第一部分有两行,分别设置调度器的实例名(instanceName) 和实例 ID (instanceId)。属性 org.quartz.scheduler.instanceName 可以是你喜欢的任何字符串。它用来在用到多个调度器区分特定的调度器实例。多个调度器通常用在集群环境中。(Quartz 集群将会在第十一章,“Quartz 集群”中讨论)。现在的话,设置如下的一个字符串就行:

org.quartz.scheduler.instanceName = QuartzScheduler

实际上,这也是当你没有该属性配置时的默认值。

代码 3.7 中显示的调度器的第二个属性是 org.quartz.scheduler.instanceId。和 instaneName 属性一样,instanceId 属性也允许任何字符串。这个值必须是在所有调度器实例中是唯一的,尤其是在一个集群当中。假如你想 Quartz 帮你生成这个值的话,可以设置为 AUTO。如果 Quartz 框架是运行在非集群环境中,那么自动产生的值将会是 NON_CLUSTERED。假如是在集群环境下使用 Quartz,这个值将会是主机名加上当前的日期和时间。大多情况下,设置为 AUTO 即可。

·线程池属性

接下来的部分是设置有关线程必要的属性值,这些线程在 Quartz 中是运行在后台担当重任的。threadCount 属性控制了多少个工作者线程被创建用来处理 Job。原则上是,要处理的 Job 越多,那么需要的工作者线程也就越多。threadCount 的数值至少为 1。Quartz 没有限定你设置工作者线程的最大值,但是在多数机器上设置该值超过100的话就会显得相当不实用了,特别是在你的 Job 执行时间较长的情况下。这项没有默认值,所以你必须为这个属性设定一个值。

threadPriority 属性设置工作者线程的优先级。优先级别高的线程比级别低的线程更优先得到执行。threadPriority 属性的最大值是常量 java.lang.Thread.MAX_PRIORITY,等于10。最小值为常量 java.lang.Thread.MIN_PRIORITY,为1。这个属性的正常值是 Thread.NORM_PRIORITY,为5。大多情况下,把它设置为5,这也是没指定该属性的默认值。

最后一个要设置的线程池属性是 org.quartz.threadPool.class。这个值是一个实现了 org.quartz.spi.ThreadPool 接口的类的全限名称。Quartz 自带的线程池实现类是 org.quartz.smpl.SimpleThreadPool,它能够满足大多数用户的需求。这个线程池实现具备简单的行为,并经很好的测试过。它在调度器的生命周期中提供固定大小的线程池。你能根据需求创建自己的线程池实现,如果你想要一个随需可伸缩的线程池时也许需要这么做。这个属性没有默认值,你必须为其指定值。

·作业存储设置

作业存储部分的设置描述了在调度器实例的生命周期中,Job 和 Trigger 信息是如何被存储的。我们还没有谈论到作业存储和它的目的;因为对当前例子是非必的,所以我们留待以后说明。现在的话,你所要了解的就是我们存储调度器信息在内存中而不是在关系型数据库中就行了。

把调度器信息存储在内存中非常的快也易于配置。当调度器进程一旦被终止,所有的 Job 和 Trigger 的状态就丢失了。要使 Job 存储在内存中需通过设置  org.quartz.jobStrore.class 属性为 org.quartz.simpl.RAMJobStore,就像在代码 3.7 所做的那样。假如我们不希望在 JVM 退出之后丢失调度器的状态信息的话,我们可以使用关系型数据库来存储这些信息。这需要另一个作业存储(JobStore) 实现,我们在后面将会讨论到。第五章“Cron Trigger 和其他”和第六章“作业存储和持久化”会提到你需要用到的不同类型的作业存储实现。

·插件配置

在这个简单的 quartz.properties 文件中最后一部分是你要用到的 Quart 插件的配置。插件常常在别的开源框架上使用到,比如 Apache 的 Struts 框架(见 http://struts.apache.org)。

一个声明式扩框架的方法就是通过新加实现了 org.quartz.spi.SchedulerPlugin 接口的类。SchedulerPlugin  接口中有给调度器调用的三个方法。



Quartz 插件会在第八章“使用 Quartz 插件”中详细讨论


要在我们的例子中声明式配置调度器信息,我们会用到一个 Quartz 自带的叫做 org.quartz.plugins.xml.JobInitializationPlugin 的插件。

默认时,这个插件会在 classpath 中搜索名为 quartz_jobs.xml 的文件并从中加载 Job 和 Trigger 信息。

在下一节中讨论 quartz_jobs.xml 文件,这是我们所参考的非正式的 Job 定义文件。



默认时,插件 JobInitializationPlugin 在 classpath 中寻找 quartz_jobs.xml 文件。你可以覆盖相应设置强制这个插件使用不同的文件名查找。要做到这个,你必须设置上一节讨论的 quartz.properties 中的文件名。目前,我们就使用默认的文件名 quartz_jobs.xml,至于如何修改 quartz.properties 中相应设置会在本章中后面讲到。


·使用 quartz_jobx.xml 文件

代码 3.8 就是目录扫描例子的 Job 定义的 XML 文件。正如代码 3.5 所示例子那样,这里我们用的是声明式途径来配置 Job 和 Trigger 信息的。

代码 3.8. ScanDirectory Job 的 quartz_jobs.xml

  1. <?xml version='1.0' encoding='utf-8'?>      
  2.       
  3. <quartz>      
  4.       
  5.   <job>      
  6.     <job-detail>      
  7.      <name>ScanDirectory</name>      
  8.      <group>DEFAULT</group>      
  9.      <description>      
  10.           A job that scans a directory for files       
  11.      </description>      
  12.      <job-class>      
  13.             org.cavaness.quartzbook.chapter3.ScanDirectoryJob       
  14.      </job-class>      
  15.      <volatility>false</volatility>      
  16.      <durability>false</durability>      
  17.      <recover>false</recover>      
  18.      <job-data-map allows-transient-data="true">      
  19.          <entry>      
  20.          <key>SCAN_DIR</key>      
  21.          <value>c:\quartz-book\input</value>      
  22.        </entry>      
  23.      </job-data-map>      
  24.     </job-detail>      
  25.       
  26.     <trigger>      
  27.      <simple>      
  28.        <name>scanTrigger</name>      
  29.        <group>DEFAULT</group>      
  30.        <job-name>ScanDirectory</job-name>      
  31.        <job-group>DEFAULT</job-group>      
  32.        <start-time>2005-06-10 6:10:00 PM</start-time>      
  33.        <!-- repeat indefinitely every 10 seconds -->      
  34.        <repeat-count>-1</repeat-count>      
  35.        <repeat-interval>10000</repeat-interval>      
  36.      </simple>      
  37.     </trigger>      
  38.       
  39.   </job>      
  40. </quartz>  


<job> 元素描述了一个要注册到调度器上的 Job,相当于我们在前面章节中使用 scheduleJob() 方法那样。你所看到的<job-detail> 和  <trigger> 这两个元素就是我们在代码 3.5 中以编程式传递给方法 schedulerJob() 的参数。前面本质上是与这里一样的,只是现在用的是一种较流行声明的方式。你还可以对照着代码 3.5 中的例子来看在代码3.8 中我们是如何设置 SCAN_DIR 属性到 JobDataMap 中的。

<trigger>元素也是非常直观的:它使用前面同样的属性,但更简单的建立一个 SimpleTrigger。因此代码 3.8 仅仅是一种不同的(可论证的且更好的)方式做了代码 3.5 中同样的事情。显然,你也可以支持多个 Job。在代码3.6 中我们编程的方式那么做的,也能用声明的方式来支持。代码 3.9 显示了与代码 3.6 可比较的版本

代码 3.9. 你能在一个 quartz_jobs.xml 文件中指定多个 Job

  1. <?xml version='1.0' encoding='utf-8'?>      
  2.       
  3. <quartz>      
  4.   <job>      
  5.     <job-detail>      
  6.      <name>ScanDirectory1</name>      
  7.      <group>DEFAULT</group>      
  8.      <description>      
  9.            A job that scans a directory for files       
  10.      </description>      
  11.      <job-class>      
  12.            org.cavaness.quartzbook.chapter3.ScanDirectoryJob       
  13.      </job-class>      
  14.      <volatility>false</volatility>      
  15.      <durability>false</durability>      
  16.      <recover>false</recover>      
  17.       
  18.      <job-data-map allows-transient-data="true">      
  19.      <entry>      
  20.        <key>SCAN_DIR</key>      
  21.          <value>c:\quartz-book\input1</value>      
  22.      </entry>      
  23.     </job-data-map>      
  24.   </job-detail>      
  25.       
  26.   <trigger>      
  27.     <simple>      
  28.      <name>scanTrigger1</name>      
  29.      <group>DEFAULT</group>      
  30.      <job-name>ScanDirectory1</job-name>      
  31.      <job-group>DEFAULT</job-group>      
  32.      <start-time>2005-07-19 8:31:00 PM</start-time>      
  33.      <!-- repeat indefinitely every 10 seconds -->      
  34.      <repeat-count>-1</repeat-count>      
  35.      <repeat-interval>10000</repeat-interval>      
  36.     </simple>      
  37.   </trigger>      
  38. </job>      
  39.       
  40. <job>      
  41.   <job-detail>      
  42.     <name>ScanDirectory2</name>      
  43.     <group>DEFAULT</group>      
  44.     <description>      
  45.           A job that scans a directory for files       
  46.     </description>      
  47.     <job-class>      
  48.           org.cavaness.quartzbook.chapter3.ScanDirectoryJob       
  49.     </job-class>      
  50.     <volatility>false</volatility>      
  51.     <durability>false</durability>      
  52.     <recover>false</recover>      
  53.       
  54.     <job-data-map allows-transient-data="true">      
  55.       <entry>      
  56.        <key>SCAN_DIR</key>      
  57.        <value>c:\quartz-book\input2</value>      
  58.      </entry>      
  59.     </job-data-map>      
  60.   </job-detail>      
  61.       
  62.   <trigger>      
  63.     <simple>      
  64.      <name>scanTrigger2</name>      
  65.      <group>DEFAULT</group>      
  66.      <job-name>ScanDirectory2</job-name>      
  67.      <job-group>DEFAULT</job-group>      
  68.      <start-time>2005-06-10 6:10:00 PM</start-time>      
  69.      <!-- repeat indefinitely every 15 seconds -->      
  70.      <repeat-count>-1</repeat-count>      
  71.      <repeat-interval>15000</repeat-interval>      
  72.     </simple>      
  73.   </trigger>      
  74.  </job>      
  75. </quartz>  


·为插件修改 quartz.properties 配置

在本章前面,告诉过你的是,JobInitializationPlugin 找寻 quartz_jobs.xml 来获得声明的 Job 信息。假如你想改变这个文件名,你需要修改 quartz.properties 来告诉插件去加载那个文件。例如,假如你想要 Quartz 从名为 my_quartz_jobs.xml 的 XML 文件中加载 Job 信息,你不得不为插件指定这一文件名。代码 3.10 显示了怎么完成这个配置;我们现在是最后一次在这里重复说明这一插件部分。

代码 3.10. 为 JobInitializationPlugin 修改 quartz.properties

  1. org.quartz.plugin.jobInitializer.class = org.quartz.plugins.xml.JobInitializationPlugin       
  2.   
  3. org.quartz.plugin.jobInitializer.fileName = my_quartz_jobs.xml       
  4.       
  5. org.quartz.plugin.jobInitializer.overWriteExistingJobs = true      
  6. org.quartz.plugin.jobInitializer.validating = false      
  7. org.quartz.plugin.jobInitializer.overWriteExistingJobs = false      
  8. org.quartz.plugin.jobInitializer.failOnFileNotFound = true    


在代码 3.10中,我们添加了属性 org.quartz.plugin.jobInitializer.fileName 并设置该属性值为我们想要的文件名。这个文件名要对 classloader 可见,也就是说要在 classpath 下。

当 Quartz 启动后读取 quartz.properties 文件,然后初始化插件。它会传递上面配置的所有属性给插件,这时候插件也就得到通知去搜寻不同的文件。

译者后记:
想了又想,关于动词的 “Schedule” 还是选择“部署”,此前用的是“安排”,感觉不那么正式。当然英语中“部署”基本都用“Deploy”对应,平时与同事交流 Quartz 方面的技术都是说“往调度器上部署一个 Job”的,只要词能达意就行。

对于 “register with the Scheduler”,有时候是用的“通过调度器来注册”,有时候是“注册到调度器上”,意思基本一致的。

分享到:
评论

相关推荐

    Quartz Job Scheduling Framework 中文版 V1.0.0.chm

    把本人博客上零零散散,顺序错乱的各篇译章汇集成册,做成了一个 《Quartz Job Scheduling Framework 中文版.chm 》文件与各位分享,以方便大家的阅读。另外,每篇译章都有到达我的博客上所对应页面的链接,所以有...

    Quartz Job Scheduling Framework 中文版 V1.0.0.rar

    Quartz Job Scheduling Framework 是一个开源的作业调度框架,它为Java应用程序提供了强大的定时任务管理功能。这个框架允许开发者创建、组织和执行定时任务,从而实现应用中的自动化工作流程。Quartz 中文版 V1.0.0...

    Quartz Job Scheduling Framework.chm

    Quartz Job Scheduling Framework.chm

    Quartz Job Scheduling Framework第11章翻译初稿

    Quartz Job Scheduling Framework是一个强大的、开放源代码的作业调度框架,它使应用程序能够在指定的时间执行任务,无需人工干预。这个框架广泛应用于Java应用程序中,用于实现定时任务和工作流管理。在第11章中,...

    Quartz Job Scheduling Framework 中文版 chm版

    中文版的Quartz Job Scheduling Framework文档是对于原英文版的翻译,方便中国开发者更好地理解和应用这个框架。CHM文件是一种Windows帮助文档格式,通常包含索引、搜索功能以及组织良好的内容,便于用户查找和学习...

    Quartz Job Scheduling Framework 中文版 V0.8.2.chm

    把本人博客上零零散散,顺序错乱的各篇译章汇集成册,做成了一个 《Quartz Job Scheduling Framework 中文版.chm 》文件与各位分享,以方便大家的阅读。另外,每篇译章都有到达我的博客上所对应页面的链接,所以有...

    Quartz Job Scheduling Framework 中文版 V0.9.5.zip

    Quartz Job Scheduling Framework 是一个广泛使用的开源作业调度框架,专为Java应用程序设计,用于创建、安排和管理作业。这个框架允许开发者精确地控制作业执行的时间,并提供了丰富的特性,包括可配置的作业触发器...

    Quartz Job Scheduling Framework 中文版 V0.9.2

    Quartz Job Scheduling Framework 是一个开源的作业调度框架,它为Java应用程序提供了强大的定时任务管理功能。这个中文版V0.9.2的文档可能是针对Quartz的一个早期版本的翻译,帮助中国开发者更好地理解和使用这一...

    Quartz Job Scheduling Framework第5章翻译初稿

    在阅读《Quartz Job Scheduling Framework》第5章时,你会了解到如何创建和配置Cron Triggers,如何结合SimpleTrigger和CalendarIntervalTrigger实现不同类型的定时任务,以及如何优化Quartz的配置以适应大规模的...

    Quartz Job Scheduling Framework 中文版

    Quartz Job Scheduling Framework 是一个强大的、开源的Java作业调度框架,它允许应用程序定义和执行复杂的定时任务。这个框架的设计目标是提供一个简单且可扩展的解决方案,用于在分布式环境中调度作业。Quartz的...

    Quartz Job Scheduling Framework

    Quartz 在开源任务调度框架中的翘首,它提供了强大任务调度机制,难能可贵的是它同时保持了使用的简单性。Quartz 允许开发人员灵活地定义触发器的调度时间表,并可以对触发器和任务进行关联映射。

    Quartz Job Scheduling Framework第2章翻译初稿

    Quartz Job Scheduling Framework是一个广泛使用的开源作业调度框架,它允许开发者在Java应用程序中精确地安排任务执行。本文档将深入探讨Quartz的核心概念、功能和实现方式,以帮助理解第2章的翻译初稿。 Quartz的...

    Quartz Job Scheduling Framework 中文版 V0.9.5.chm

    本人首个译作,Quartz 一个纯 Java 实现的作业调度框架。把本人博客上零零散散的翻译日志集成册,升级为 V0.9.5,补上了附录。 请到 http://download.csdn.net/source/2752654 下载最新V1.0.0.pdf 版 请到 ...

    Quartz Job Scheduling Framework 中文版 V0.9.1.chm

    请到 http://download.csdn.net/source/2752654 下载最新V1.0.0.pdf 版 请到 http://download.csdn.net/source/2746469 下载最新V1.0.0.chm 版

    Quartz Job Scheduling Framework 中文版 V0.9.2.chm

    请到 http://download.csdn.net/source/2752654 下载最新V1.0.0.pdf 版 请到 http://download.csdn.net/source/2746469 下载最新V1.0.0.chm 版

Global site tag (gtag.js) - Google Analytics