`
yahaitt
  • 浏览: 760793 次
  • 性别: Icon_minigender_2
  • 来自: 杭州
社区版块
存档分类
最新评论

定时器quartz的应用

阅读更多

用quartz可以实现web或非web模式的定时器

1、配置文件

quartz_job.xml
  1. <!---->xml version="1.0" encoding="UTF-8"?>  
  2. <quartz xmlns="http://www.opensymphony.com/quartz/JobSchedulingData"  
  3.         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  4.         overwrite-existing-jobs="true">  
  5.        
  6.     <job>  
  7.         <job-detail>  
  8.             <name>yayaittname>  
  9.             <group>CRAWLER_JOB_GROUPgroup>  
  10.   
  11.             <description>send task per daydescription>  
  12.             <job-class>com.yahaitt.quartz.QuartzSystemjob-class>  
  13.   
  14.             <job-data-map allows-transient-data="true">  
  15.                <entry>  
  16.                     <key>usernamekey>  
  17.                     <value>wujinlivalue>  
  18.                 entry>  
  19.                 <entry>  
  20.                     <key>passwordkey>  
  21.                     <value>mahaibovalue>  
  22.   
  23.                 entry>  
  24.             job-data-map>  
  25.         job-detail>  
  26.         <trigger>  
  27.             <cron>  
  28.                 <name>hourTaskJob-triggername>  
  29.                 <group>CRAWLER_TRIGGER_GROUPgroup>  
  30.                 <job-name>yayaittjob-name>  
  31.                 <job-group>CRAWLER_JOB_GROUPjob-group>  
  32.   
  33.   
  34.                 <cron-expression>1/12 * * * * ?cron-expression>  
  35.   
  36.             cron>  
  37.         trigger>  
  38.     job>  
  39.   
  40.        
  41.        
  42.        
  43.      
  44. quartz>  

该定时器实现了每12秒触发类com.yahaitt.quartz.QuartzSystem的execute函数,并通过java-data-map标签来实现参数的传递,如果不需要传递参数,可以将整个java-data-map标签去除。

需要注意的是job-detail与trigger中各子标签间的关系,比如trigger中job-name和job-group要与job-detail中的name和group对应。

可以通过在quartz标签中添加多个job来实现多个定时器的管理。

2、定义org.quartz.Job接口的实现类

QuartzSystem.java
  1. package com.yahaitt.quartz;   
  2.   
  3. import org.quartz.Job;   
  4. import org.quartz.JobExecutionContext;   
  5. import org.quartz.JobExecutionException;   
  6.   
  7. public class QuartzSystem implements Job {   
  8.   
  9.     public void execute(JobExecutionContext context) throws JobExecutionException {   
  10.         // TODO Auto-generated method stub   
  11.            
  12.         String username = context.getJobDetail().getJobDataMap().getString("username");   
  13.         String password = context.getJobDetail().getJobDataMap().getString("password");   
  14.         System.out.println("username:" + username);   
  15.         System.out.println("password:" + password);   
  16.     }   
  17.   
  18. }   

通过调用JobExecutionContext 的getJobDetail().getJobDataMap().getString(String paramname)来取得配置文件中定义的参数的值。

当定时器触发时,将执行该类的execute函数。

3、设置监听器

TaskScheduler.java
  1. package com.yahaitt.quartz;   
  2.   
  3. import java.util.Properties;   
  4.   
  5. import org.apache.log4j.Logger;   
  6. import org.quartz.Scheduler;   
  7. import org.quartz.SchedulerException;   
  8. import org.quartz.SchedulerFactory;   
  9. import org.quartz.impl.StdSchedulerFactory;   
  10. import org.quartz.xml.JobSchedulingDataProcessor;   
  11.   
  12.   
  13. public class TaskScheduler {   
  14.     // Logger   
  15.     private static Logger logger = Logger.getLogger(TaskScheduler.class);   
  16.        
  17.     private static Scheduler scheduler;   
  18.        
  19.     private String jobsConfigFile = "quartz-jobs.xml";   
  20.        
  21.     public TaskScheduler() {   
  22.         initScheduler();   
  23.     }   
  24.        
  25.     /**  
  26.      *   
  27.      * @param fileName  
  28.      * @return  
  29.      */  
  30.     public void initScheduler() {   
  31.         try {   
  32.             StdSchedulerFactory factory = new StdSchedulerFactory();   
  33.             //   
  34.             Properties properties = new Properties();   
  35.             properties.put("org.quartz.scheduler.instanceName","DefaultQuartzScheduler");   
  36.             properties.put("org.quartz.scheduler.rmi.export","false");   
  37.             properties.put("org.quartz.scheduler.rmi.proxy","false");   
  38.             properties.put("org.quartz.scheduler.wrapJobExecutionInUserTransaction","false");   
  39.             properties.put("org.quartz.threadPool.class","org.quartz.simpl.SimpleThreadPool");   
  40.             properties.put("org.quartz.threadPool.threadCount","20");   
  41.             properties.put("org.quartz.threadPool.threadPriority","5");   
  42.             properties.put("org.quartz.threadPool.threadsInheritContextClassLoaderOfInitializingThread","true");   
  43.             properties.put("org.quartz.jobStore.misfireThreshold","60000");   
  44.             properties.put("org.quartz.jobStore.class","org.quartz.simpl.RAMJobStore");   
  45. //          org.quartz.plugin.jobInitializer.validating = false   
  46. //          org.quartz.plugin.jobInitializer.validatingSchema = false   
  47. //          org.quartz.plugin.jobInitializer.class = org.quartz.plugins.xml.JobInitializationPlugin   
  48. //          org.quartz.plugin.jobInitializer.fileName = quartz-jobs.xml   
  49. //          org.quartz.plugin.jobInitializer.overWriteExistingJobs = false   
  50. //          org.quartz.plugin.jobInitializer.failOnFileNotFound = true    
  51.             factory.initialize(properties);   
  52.             SchedulerFactory sf = (StdSchedulerFactory)factory;   
  53.             scheduler = sf.getScheduler();   
  54.             //Placing a Scheduler in Stand-by Mode   
  55.             //scheduler.standby();   
  56.         } catch (SchedulerException e) {   
  57.             e.printStackTrace();   
  58.             logger.error(e);   
  59.         }   
  60.     }   
  61.        
  62.     /**  
  63.      * 从指定的任务配置文件中初始化计划任务  
  64.      * @param jobsConfig  
  65.      * @throws Exception  
  66.      */  
  67.     public void initJobs(String jobsConfig) throws Exception {   
  68.         //   
  69.         this.jobsConfigFile = jobsConfig;   
  70.         //   
  71.         JobSchedulingDataProcessor xmlProcessor = new JobSchedulingDataProcessor();   
  72.         //the last parameter here (the boolean one)is for overwriting existing jobs   
  73.         xmlProcessor.processFileAndScheduleJobs(jobsConfigFile, scheduler, true);   
  74.     }   
  75.        
  76.     /**  
  77.      * 开启计划任务  
  78.      * @throws SchedulerException  
  79.      */  
  80.     public void startScheduler() throws SchedulerException {   
  81.         //   Scheduler will not execute jobs until it has been started (though they can be scheduled before start())    
  82.         scheduler.start();   
  83.     }   
  84.        
  85.     /**  
  86.      * 停止计划任务  
  87.      * @throws SchedulerException  
  88.      */  
  89.     public void shutdownScheduler() throws SchedulerException {   
  90.         scheduler.shutdown();   
  91.     }   
  92.        
  93.     /**  
  94.      * @param args  
  95.      */  
  96.     public static void main(String[] args) {   
  97.         String jobsConfigfile = "E:/workspace/crawler/conf/quartz_job.xml";   
  98.         TaskScheduler scheduler = new TaskScheduler();   
  99.         try {   
  100.             scheduler.initJobs(jobsConfigfile);   
  101.             scheduler.startScheduler();   
  102.         } catch (Exception e) {   
  103.             e.printStackTrace();   
  104.         }   
  105.   
  106.     }   
  107.   
  108. }   
分享到:
评论
1 楼 yahaitt 2007-09-10  
只有当执行
scheduler.initJobs(jobsConfigfile);   
scheduler.startScheduler();
后,定时器才会被启动。
所以,在web中应用时,可以写一个servlet程序,在其init函数中new一个TaskScheduler,并初始化和启动这个TaskScheduler,并通过在web.xml中设置
<load-on-startup>1</load-on-startup>
使得在web服务器启动时将定时器启动。

相关推荐

    SSM定时器quartz DEMO

    SSM定时器Quartz是一个广泛使用的Java定时任务框架,它允许开发者在应用程序中安排复杂的作业执行计划。在Java世界里,Quartz是一个强大的工具,它能够处理大量的并发任务,并提供了丰富的API来创建、调度和管理任务...

    Spring定时器quartz

    Spring定时器Quartz是Java应用中广泛使用的任务调度框架,它允许开发者定义并执行复杂的定时任务。这篇博客可能探讨了如何在Spring框架中集成Quartz,以实现灵活、可扩展的任务调度。 Quartz是一个开源的作业调度...

    定时器quartz API文档

    7. **持久化**:Quartz支持通过JDBC JobStore实现数据持久化,这样即使应用程序重启,Job和Trigger的状态也能被恢复,保证任务的连续性。 8. **并发与集群**:Quartz允许在多台服务器上部署同一个Scheduler实例,...

    定时器quartz的使用方法

    本教程将详细讲解如何使用Quartz实现一个简单的定时器功能。 首先,我们需要引入Quartz的依赖库到项目中。如果你使用的是Maven,可以在pom.xml文件中添加以下依赖: ```xml &lt;groupId&gt;org.quartz-scheduler ...

    定时器quartZ

    【标题】:“定时器Quartz” Quartz是一个开源的工作调度框架,它允许程序在特定时间执行任务,类似于Java中的ScheduledExecutorService,但提供了更高级别的功能。Quartz主要用于企业级应用,可以创建、调度和执行...

    定时器Quartz.net2.0内置操作类

    在标题提到的"定时器Quartz.net2.0内置操作类"中,我们主要关注的是如何利用Quartz.NET 2.0版本提供的API来简化任务调度。 Quartz.NET 2.0的核心组件包括`IScheduler`、`IJob`和`ITrigger`。`IScheduler`是调度器...

    定时器的配置文件(两种方式:springmvc自带定时,Quartz与spring结合的定时)

    本篇文章将详细讲解两种在Spring MVC框架中实现定时任务的方法:Spring MVC自带的定时器以及Quartz与Spring的集成。 首先,我们来看看Spring MVC自带的定时任务。Spring MVC作为Spring框架的一个模块,主要处理HTTP...

    Java定时器 quartz jar包

    Quartz是OpenSymphony开源组织在Job scheduling领域又一个开源项目,它可以与J2EE与J2SE应用程序相结合也可以单独使用。Quartz可以用来创建简单或为运行十个,百个,甚至是好几万个Jobs这样复杂的程序。Jobs可以做成...

    定时器 quartz 和 spring

    标题 "定时器 quartz 和 spring" 涉及到的是两个在Java开发中非常重要的框架——Quartz和Spring。Quartz是一个开源的工作调度框架,它允许开发者创建、调度和执行任务,而Spring则是一个功能丰富的应用程序框架,...

    java开源定时器Quartz

    Quartz是一款功能强大的Java开源定时任务框架,它允许开发者创建、调度和执行各种类型的任务,以实现应用程序的自动化和批处理。Quartz以其灵活的API、丰富的特性以及稳定性,成为了许多企业级应用首选的定时解决...

    JAVA定时器Quartz及使用说明

    Quartz是一款功能强大的开源Java定时框架,用于在Java应用程序中创建和管理计划任务。它允许开发者精确地安排作业,从简单的一次性任务到复杂的调度模式。Quartz 1.5.2是该项目的一个较旧版本,但它仍然包含了实现...

    定时器Quartz使用说明

    **Quartz** 是一款开源的任务调度框架,广泛应用于 Java 应用程序中。它的主要功能是帮助开发者以灵活的方式调度任务,支持复杂的触发规则。 - **嵌入式运行**:Quartz 可以无缝地嵌入到任何独立的应用程序中运行,...

    Quartz定时器web应用

    Quartz是一款开源的作业调度...总结来说,"Quartz定时器web应用"示例展示了如何在Web环境中利用Quartz框架创建和调度定时任务。通过理解上述概念和步骤,开发者可以灵活地构建和管理定时任务,提升系统的自动化水平。

    Spring-quartz实现定时器(含代码)

    本文将深入探讨如何使用Spring整合Quartz来实现定时器,并提供相关代码示例。 首先,理解Spring框架。Spring是一个开源的Java平台,它提供了全面的企业级应用程序开发解决方案,包括依赖注入(DI)、面向切面编程...

    springmvc+mybatis+动态定时器quartz

    Spring MVC、MyBatis 和 Quartz 是企业级应用开发中常用的三个技术组件,它们分别负责不同的功能领域。Spring MVC 是一个轻量级的基于模型-视图-控制器(MVC)设计模式的Web 应用框架,它使得Java开发者能够轻松地...

Global site tag (gtag.js) - Google Analytics