quartz(4)--quartz.properties文件

 

Quartz有一个叫做quartz.properties的配置文件,它允许你修改框架运行时环境。缺省是使用Quartz.jar里面的quartz.properties文件。当然你应该创建一个quartz.properties文件并且把它放入你工程的classes目录中以便类装载器找到它。

一旦将Quartz.jar文件和第三方库加到自己的工程里面并且quartz.properties文件在工程的classes目录中,就可以创建作业了。

 

#跳过版本更新检查
org.quartz.scheduler.skipUpdateCheck: true

#调度器属性配置 
org.quartz.scheduler.instanceName = derella-web-scheduler-dev
org.quartz.scheduler.instanceId = AUTO
org.quartz.scheduler.instanceIdGenerator.class = org.quartz.simpl.HostnameInstanceIdGenerator

#线程池配置
org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPool
org.quartz.threadPool.threadCount = 30
org.quartz.threadPool.threadPriority = 5

# 作业存储配置  
# 信息保存时间 默认值60秒  
org.quartz.jobStore.misfireThreshold = 60000
#保存job和Trigger的状态信息到内存中,设置为     
org.quartz.jobStore.class = org.quartz.impl.jdbcjobstore.JobStoreTX
org.quartz.jobStore.driverDelegateClass = org.quartz.impl.jdbcjobstore.StdJDBCDelegate
org.quartz.jobStore.useProperties = false
org.quartz.jobStore.dataSource = myDS
#表的别名默认QRTZ_
org.quartz.jobStore.tablePrefix = QRTZ_
#true支持集群
org.quartz.jobStore.isClustered = true
org.quartz.jobStore.clusterCheckinInterval = 20000
#org.quartz.jobStore.maxMisfiresToHandleAtATime = 20

#数据源信息
org.quartz.dataSource.myDS.driver = com.mysql.jdbc.Driver
org.quartz.dataSource.myDS.URL = jdbc:mysql://localhost:3306/test?characterEncoding=utf-8
org.quartz.dataSource.myDS.user = test
org.quartz.dataSource.myDS.password = test
org.quartz.dataSource.myDS.maxConnections = 5

调度器属性

分别设置调度器的实例名(instanceName) 和实例 ID (instanceId)。属性 org.quartz.scheduler.instanceName 可以是你喜欢的任何字符串。默认名字一般都采用QuartzScheduler,第二个属性org.quartz.scheduler.instanceId和instaneName 属性一样,instanceId 属性也允许任何字符串。这个值必须是在所有调度器实例中是唯一的,尤其是在一个集群当中。假如你想 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,在Cron Trigger 和“作业存储和持久化”会用到的不同类型的作业存储实现。

 

案例1中,如何使quartz.properties文件生效?

根据不同环境,加载不同配置文件到工程的classes目录即可生效

启动应用后,查看配置文件加载情况。

成功放入class目录

 

 案例2中,如何配置quartz属性?

   <!-- 配置scheduler 如果将lazy-init='false'那么容器启动就会执行调度程序  --> 
     <bean id="quartzScheduler" lazy-init="false" autowire="no" class="org.springframework.scheduling.quartz.SchedulerFactoryBean"> 
         <property name="quartzProperties">
            <props>
                <!-- 调度器属性配置  -->
                <prop key="org.quartz.scheduler.instanceId">AUTO</prop>
                <prop key="org.quartz.scheduler.instanceIdGenerator.class">org.quartz.simpl.HostnameInstanceIdGenerator</prop>
                <!-- 线程池配置 -->
                <prop key="org.quartz.threadPool.class">org.quartz.simpl.SimpleThreadPool</prop>
                <prop key="org.quartz.threadPool.threadCount">30</prop>
                <prop key="org.quartz.threadPool.threadPriority">5</prop>
                <!-- 作业存储配置   -->
                <prop key="org.quartz.jobStore.misfireThreshold">60000</prop>
                <prop key="org.quartz.jobStore.class">org.quartz.simpl.RAMJobStore</prop>
            </props>
        </property>
        <property name="schedulerName" value="derella-web-scheduler" />
        
        <!-- 触发器 --> 
        <property name="triggers"> 
             <list> 
                <ref bean = "testJobTrigger" />
             </list> 
        </property> 
     </bean>

或者更简洁的

   <!-- 配置scheduler 如果将lazy-init='false'那么容器启动就会执行调度程序  --> 
     <bean id="scheduler" lazy-init="false" autowire="no" class="org.springframework.scheduling.quartz.SchedulerFactoryBean"> 
        <property name="configLocation" value="classpath:quartz.properties"></property>
        <property name="schedulerName" value="derella-web-scheduler-spring" />
        <!-- 触发器 --> 
        <property name="triggers"> 
             <list> 
                <!-- <ref bean = "testJobTrigger" /> -->
             </list> 
        </property> 
     </bean>

 

测试配置:

@Controller
@RequestMapping("quartz")
public class QuartzController {

    @Resource
    private Scheduler scheduler;

    @RequestMapping(value = "/testSpringQuartzScheduler.htm", method = RequestMethod.GET)
    @ResponseBody
    public String testSpringQuartzScheduler() throws SchedulerException {
        return scheduler.getSchedulerName();
    }
}

请求http://localhost:12342/derella-web/quartz/testSpringQuartzScheduler.htm,返回值为derella-web-scheduler

 

posted on 2017-03-09 16:14  芹derella  阅读(686)  评论(0编辑  收藏  举报