`
小嘴冰凉
  • 浏览: 447825 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Quartz quartz.properties 文件

阅读更多
[size=medium]

3. 声明式部署一个 Job 

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

·配置 quartz.properties 文件

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

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

注

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

代码 3.7. 基本的 Quartz Properties 文件

#===============================================================     
#Configure Main Scheduler Properties     
#===============================================================       
org.quartz.scheduler.instanceName = QuartzScheduler       
org.quartz.scheduler.instanceId = AUTO     
 
#===============================================================     
#Configure ThreadPool     
#===============================================================       
org.quartz.threadPool.threadCount =  5       
org.quartz.threadPool.threadPriority = 5       
org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPool     
 
#===============================================================     
#Configure JobStore     
#===============================================================       
org.quartz.jobStore.class = org.quartz.simpl.RAMJobStore     
 
#===============================================================     
#Configure Plugins     
#===============================================================       
org.quartz.plugin.jobInitializer.class =       
org.quartz.plugins.xml.JobInitializationPlugin       
      
org.quartz.plugin.jobInitializer.overWriteExistingJobs = true      
org.quartz.plugin.jobInitializer.failOnFileNotFound = true      
org.quartz.plugin.jobInitializer.validating=false  
#===============================================================   
#Configure Main Scheduler Properties   
#===============================================================    
org.quartz.scheduler.instanceName = QuartzScheduler    
org.quartz.scheduler.instanceId = AUTO   

#===============================================================   
#Configure ThreadPool   
#===============================================================    
org.quartz.threadPool.threadCount =  5    
org.quartz.threadPool.threadPriority = 5    
org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPool   

#===============================================================   
#Configure JobStore   
#===============================================================    
org.quartz.jobStore.class = org.quartz.simpl.RAMJobStore   

#===============================================================   
#Configure Plugins   
#===============================================================    
org.quartz.plugin.jobInitializer.class =    
org.quartz.plugins.xml.JobInitializationPlugin    
   
org.quartz.plugin.jobInitializer.overWriteExistingJobs = true   
org.quartz.plugin.jobInitializer.failOnFileNotFound = true   
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

<?xml version='1.0' encoding='utf-8'?>      
      
<quartz>      
      
  <job>      
    <job-detail>      
     <name>ScanDirectory</name>      
     <group>DEFAULT</group>      
     <description>      
          A job that scans a directory for files       
     </description>      
     <job-class>      
            org.cavaness.quartzbook.chapter3.ScanDirectoryJob       
     </job-class>      
     <volatility>false</volatility>      
     <durability>false</durability>      
     <recover>false</recover>      
     <job-data-map allows-transient-data="true">      
         <entry>      
         <key>SCAN_DIR</key>      
         <value>c:\quartz-book\input</value>      
       </entry>      
     </job-data-map>      
    </job-detail>      
      
    <trigger>      
     <simple>      
       <name>scanTrigger</name>      
       <group>DEFAULT</group>      
       <job-name>ScanDirectory</job-name>      
       <job-group>DEFAULT</job-group>      
       <start-time>2005-06-10 6:10:00 PM</start-time>      
       <!-- repeat indefinitely every 10 seconds -->      
       <repeat-count>-1</repeat-count>      
       <repeat-interval>10000</repeat-interval>      
     </simple>      
    </trigger>      
      
  </job>      
</quartz>  
<?xml version='1.0' encoding='utf-8'?>   
   
<quartz>   
   
  <job>   
    <job-detail>   
     <name>ScanDirectory</name>   
     <group>DEFAULT</group>   
     <description>   
          A job that scans a directory for files    
     </description>   
     <job-class>   
            org.cavaness.quartzbook.chapter3.ScanDirectoryJob    
     </job-class>   
     <volatility>false</volatility>   
     <durability>false</durability>   
     <recover>false</recover>   
     <job-data-map allows-transient-data="true">   
         <entry>   
         <key>SCAN_DIR</key>   
         <value>c:\quartz-book\input</value>   
       </entry>   
     </job-data-map>   
    </job-detail>   
   
    <trigger>   
     <simple>   
       <name>scanTrigger</name>   
       <group>DEFAULT</group>   
       <job-name>ScanDirectory</job-name>   
       <job-group>DEFAULT</job-group>   
       <start-time>2005-06-10 6:10:00 PM</start-time>   
       <!-- repeat indefinitely every 10 seconds -->   
       <repeat-count>-1</repeat-count>   
       <repeat-interval>10000</repeat-interval>   
     </simple>   
    </trigger>   
   
  </job>   
</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

<?xml version='1.0' encoding='utf-8'?>      
      
<quartz>      
  <job>      
    <job-detail>      
     <name>ScanDirectory1</name>      
     <group>DEFAULT</group>      
     <description>      
           A job that scans a directory for files       
     </description>      
     <job-class>      
           org.cavaness.quartzbook.chapter3.ScanDirectoryJob       
     </job-class>      
     <volatility>false</volatility>      
     <durability>false</durability>      
     <recover>false</recover>      
      
     <job-data-map allows-transient-data="true">      
     <entry>      
       <key>SCAN_DIR</key>      
         <value>c:\quartz-book\input1</value>      
     </entry>      
    </job-data-map>      
  </job-detail>      
      
  <trigger>      
    <simple>      
     <name>scanTrigger1</name>      
     <group>DEFAULT</group>      
     <job-name>ScanDirectory1</job-name>      
     <job-group>DEFAULT</job-group>      
     <start-time>2005-07-19 8:31:00 PM</start-time>      
     <!-- repeat indefinitely every 10 seconds -->      
     <repeat-count>-1</repeat-count>      
     <repeat-interval>10000</repeat-interval>      
    </simple>      
  </trigger>      
</job>      
      
<job>      
  <job-detail>      
    <name>ScanDirectory2</name>      
    <group>DEFAULT</group>      
    <description>      
          A job that scans a directory for files       
    </description>      
    <job-class>      
          org.cavaness.quartzbook.chapter3.ScanDirectoryJob       
    </job-class>      
    <volatility>false</volatility>      
    <durability>false</durability>      
    <recover>false</recover>      
      
    <job-data-map allows-transient-data="true">      
      <entry>      
       <key>SCAN_DIR</key>      
       <value>c:\quartz-book\input2</value>      
     </entry>      
    </job-data-map>      
  </job-detail>      
      
  <trigger>      
    <simple>      
     <name>scanTrigger2</name>      
     <group>DEFAULT</group>      
     <job-name>ScanDirectory2</job-name>      
     <job-group>DEFAULT</job-group>      
     <start-time>2005-06-10 6:10:00 PM</start-time>      
     <!-- repeat indefinitely every 15 seconds -->      
     <repeat-count>-1</repeat-count>      
     <repeat-interval>15000</repeat-interval>      
    </simple>      
  </trigger>      
 </job>      
</quartz>  
<?xml version='1.0' encoding='utf-8'?>   
   
<quartz>   
  <job>   
    <job-detail>   
     <name>ScanDirectory1</name>   
     <group>DEFAULT</group>   
     <description>   
           A job that scans a directory for files    
     </description>   
     <job-class>   
           org.cavaness.quartzbook.chapter3.ScanDirectoryJob    
     </job-class>   
     <volatility>false</volatility>   
     <durability>false</durability>   
     <recover>false</recover>   
   
     <job-data-map allows-transient-data="true">   
     <entry>   
       <key>SCAN_DIR</key>   
         <value>c:\quartz-book\input1</value>   
     </entry>   
    </job-data-map>   
  </job-detail>   
   
  <trigger>   
    <simple>   
     <name>scanTrigger1</name>   
     <group>DEFAULT</group>   
     <job-name>ScanDirectory1</job-name>   
     <job-group>DEFAULT</job-group>   
     <start-time>2005-07-19 8:31:00 PM</start-time>   
     <!-- repeat indefinitely every 10 seconds -->   
     <repeat-count>-1</repeat-count>   
     <repeat-interval>10000</repeat-interval>   
    </simple>   
  </trigger>   
</job>   
   
<job>   
  <job-detail>   
    <name>ScanDirectory2</name>   
    <group>DEFAULT</group>   
    <description>   
          A job that scans a directory for files    
    </description>   
    <job-class>   
          org.cavaness.quartzbook.chapter3.ScanDirectoryJob    
    </job-class>   
    <volatility>false</volatility>   
    <durability>false</durability>   
    <recover>false</recover>   
   
    <job-data-map allows-transient-data="true">   
      <entry>   
       <key>SCAN_DIR</key>   
       <value>c:\quartz-book\input2</value>   
     </entry>   
    </job-data-map>   
  </job-detail>   
   
  <trigger>   
    <simple>   
     <name>scanTrigger2</name>   
     <group>DEFAULT</group>   
     <job-name>ScanDirectory2</job-name>   
     <job-group>DEFAULT</job-group>   
     <start-time>2005-06-10 6:10:00 PM</start-time>   
     <!-- repeat indefinitely every 15 seconds -->   
     <repeat-count>-1</repeat-count>   
     <repeat-interval>15000</repeat-interval>   
    </simple>   
  </trigger>   
 </job>   
</quartz>
·为插件修改 quartz.properties 配置

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

代码 3.10. 为 JobInitializationPlugin 修改 quartz.properties

org.quartz.plugin.jobInitializer.class = org.quartz.plugins.xml.JobInitializationPlugin       
  
org.quartz.plugin.jobInitializer.fileName = my_quartz_jobs.xml       
      
org.quartz.plugin.jobInitializer.overWriteExistingJobs = true      
org.quartz.plugin.jobInitializer.validating = false      
org.quartz.plugin.jobInitializer.overWriteExistingJobs = false      
org.quartz.plugin.jobInitializer.failOnFileNotFound = true    
org.quartz.plugin.jobInitializer.class = org.quartz.plugins.xml.JobInitializationPlugin    

org.quartz.plugin.jobInitializer.fileName = my_quartz_jobs.xml    
   
org.quartz.plugin.jobInitializer.overWriteExistingJobs = true   
org.quartz.plugin.jobInitializer.validating = false   
org.quartz.plugin.jobInitializer.overWriteExistingJobs = false   
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”,有时候是用的“通过调度器来注册”,有时候是“注册到调度器上”,意思基本一致的。 
[/size]


http://www.blogjava.net/Unmi/category/27619.html
分享到:
评论
2 楼 shehun 2010-09-01  
请教一个问题
<start-time>2005-06-10 6:10:00 PM</start-time>
这个时间这样写可以吗?我测试怎嘛不行啊
1 楼 xiaotian_ls 2010-08-14  
感谢提供的文档

相关推荐

    quartz.properties

    quartz.properties

    SpringBoot-Quartz.rar

    以下为配置文件 # 固定前缀org.quartz # 主要分为scheduler、threadPool、jobStore、dataSource等部分 #============================================================== #Configure Main Scheduler Properties #=...

    cmpp3.0_JAVA.rar

    2.修改MsgConfig.properties配置文件对应的内容为可用参数。 3.方法入口:common.msg.util.MsgContainer sendWapPushMsg(String url,String desc,String cusMsisdn):发送web push短信; sendMsg(String msg,...

    quartz声明事j2EE实现

    quartz quartz-1.5.2.jar quartz.properties quartz_job.xml 实现在J2ee下quartz声明事CornTrigger,jobDetail的配置文件和类

    QuartzSpring

    你会问为什么用spring后就不用 quartz.properties quartz-jobsxml这两个文件了么? 我回答:是的,它会自动找到quartz包中默认的这两个文件,如果你有特殊需要,也可以自己定义这两个文件。 附:quartz....

    基于spring boot任务管理系统源代码.zip

    在resources/application.properties 以及quartz.properties文件中替换为自己的数据源。 运行Application main方法启动项目,项目启动会自动创建一个测试任务 见:com.itstyle.quartz.config.TaskRunner.java。 项目...

    基于spring-boot+quartz的CRUD动态任务管理系统源码+数据库,适用于中小项目

    开发环境 基于spring-boot+quartz的CRUD动态任务管理... 在resources/application.properties 以及quartz.properties文件中替换为自己的数据源。 运行Application main方法,启动项目,项目启动会初始化一个定时任务

    quartz-mongo-demo

    quartz-mongo-demo该实例中,将定时任务 ...1、修改properties/quartz_test.properties 中Mongodb为你自己的Mongodb地址、端口号及数据库 2、修改spring/mongodb.xml中Mongodb为你自己的Mongodb地址、端口号及数据库

    Quartz分布式调度

    解压之后可以直接运行,先执行数据库脚本tables_mysql_innodb.sql,之后运行代码中MainTest测试类,...主要配置文件为applicationContext.xml,applicationContext-quartz.xml,quartz.properties,jdbc.properties。

    Quartz定时任务处理案例基于jsp

    这是一个完整的使用Quartz定时处理案例,虽然简单,但是一个可运行的案例项目,包括了Quartz的包,及配置文件quartz.properties和quartz_jobs.xml文件的配置方法,及在web.xml文件中配置Quartz等方法。看了这个例子...

    quartz定时任务,在web项目中的使用方法

    quartz定时任务,在web项目中的使用方法;有例子和包直接拿到工程里陪陪就能用

    quartz-redis-jobstore:使用Redis的Quartz Scheduler JobStore

    石英-redis-jobstore 使用 JobStore。 该项目的灵感来自 ,并提供了相似的功能,但有一些主要区别: Redis数据库和密钥前缀是...配置在quartz.properties文件中可以设置以下属性: # set the scheduler's JobStore cla

    quartz 调用两次任务

    NULL 博文链接:https://zx527291227.iteye.com/blog/1680575

    quartz job持久化

    实现把job持久化数据库,里面有...1.2 Quartz配置文件quartz.properties 4 1.3 创建job 6 1.3.1 实现org.quartz.Job接口 6 1.3.2 把以上job持久化到数据库中 6 1.4 启动job所需条件 6 1.4.1 在web.xml中加入如下监听 6

    Quartz-Job-Scheduling-Framework-中文版-V0.9.1.zip

    以及如何通过 java.util.Properties 实例或默认 quartz.properties 文件创建 Scheduler。 第四章. 部署 Job (第二部分) 内容提要:如何管理 Scheduler(启动、停止、Standby 模式)。还介绍了 Job、...

    SpringBoot中整合quartz示例代码

    SpringBoot中整合quartz示例代码

    springboot2.0整合quartz

    springboot2.0整合quartz,采用 spring-boot-starter-quartz方式,更为简单方式

    spring中quartz定时任务实例及配置说明

    分享项目中使用到的spring中quartz定时任务文件,其中有quartz.xml demo实例,非常清楚每个步骤和流程,也有配置文件 quartz.properties 详细说明,如有不足之处,请多指教,谢谢!

    springboot 集成quartz

    亲测可用,springboot整合quartz。包含2个核心类QuartzConfiguration类和JobFactory类,修改数据库连接application和quartz.properties直接运行,访问http://localhost:8080/index。

    quartz+ibatis+oracle/mysql\quartz+hibernate+oracle/mysql

    项目用eclipse 导入 不同的数据库 请在数据库运行不同的SQL 脚本 用hibernate 时注意 是什么数据库 hibernate.properties 文件第一二行自行更改数据库类型 如果不能正常运行、欢迎联系我、一起讨论 。

Global site tag (gtag.js) - Google Analytics