原文链接:http://lavasoft.blog.51cto.com/62575/93938

Quartz 是个开源的作业调度框架,为在 Java 应用程序中进行作业调度提供了简单却强大的机制。Quartz框架包含了调度器监听、作业和触发器监听。你可以配置作业和触发器监听为全局监听或者是特定于作业和触发器的监听。Quartz 允许开发人员根据时间间隔(或天)来调度作业。它实现了作业和触发器的多对多关系,还能把多个作业与不同的触发器关联。整合了 Quartz 的应用程序可以重用来自不同事件的作业,还可以为一个事件组合多个作业。Quartz在功能上远远超越了JDK自带的Timer,很好很强大!
 
相关网站:
 
下面是官方的一个入门例子,我做了部分改动,添加上了中文注释,主要是了解Quartz 的工作方式和试用方法。
 
package org.quartz.examples.example1;

import java.util.Date;

import org.apache.commons.logging.Log; 
import org.apache.commons.logging.LogFactory; 
import org.quartz.JobDetail; 
import org.quartz.Scheduler; 
import org.quartz.SchedulerFactory; 
import org.quartz.SimpleTrigger; 
import org.quartz.TriggerUtils; 
import org.quartz.impl.StdSchedulerFactory;

/** 
* This Example will demonstrate how to start and shutdown the Quartz 
* scheduler and how to schedule a job to run in Quartz. 

* @author Bill Kratzer 
*/ 
public class SimpleExample {

public void run() throws Exception { 
        Log log = LogFactory.getLog(SimpleExample.class);

log.info("------- 初始化开始 ----------------------"); 
        // 首先创建一个调度程序工厂 
        SchedulerFactory schedulerFactory = new StdSchedulerFactory(); 
        // 从工厂获取一个调度程序实例 
        Scheduler scheduler = schedulerFactory.getScheduler(); 
        log.info("------- 初始化完成 -----------");

log.info("------- 调度任务 -------------------");

// 设置作业调度时间:某一时间后的下一秒 
        Date runTime = TriggerUtils.getEvenMinuteDate(new Date());

// 定义一个具体作业job1,并加入group1组,并且绑定到具体的作业类HelloJob上 
        JobDetail jobDetail = new JobDetail("job1", "group1", HelloJob.class);

// 创建一个简单的触发器 
        SimpleTrigger simpleTrigger = new SimpleTrigger("trigger1", "group1"); 
        // 设置触发时间 
        simpleTrigger.setStartTime(runTime); 
        // 设置重复执行周期 
        simpleTrigger.setRepeatInterval(2000); 
        // 设置重复执行次数 
        simpleTrigger.setRepeatCount(3);

// 设置调度的具体作业和相关的触发器 
        scheduler.scheduleJob(jobDetail, simpleTrigger); 
        log.info(jobDetail.getFullName() + " 将在某时刻: " + runTime +" 运行!");

// 启动调度程序 
        scheduler.start(); 
        log.info("------- 已启动调度程序 -----------------");

// wait long enough so that the scheduler as an opportunity to  
        // run the job! 
        log.info("------- 等待15秒... -------------"); 
        try { 
            // 等待15秒显示 
            Thread.sleep(15L * 1000L); 
            // 执行...... 
        } catch (Exception e) { 
        }

// 关闭调度程序 
        log.info("------- 关闭调度程序开始 ---------------------"); 
        scheduler.shutdown(true); 
        log.info("------- 关闭调度程序完成 -----------------"); 
    }

public static void main(String[] args) throws Exception {

SimpleExample example = new SimpleExample(); 
        example.run();


}

 
package org.quartz.examples.example1;

import org.apache.commons.logging.Log; 
import org.apache.commons.logging.LogFactory; 
import org.quartz.Job; 
import org.quartz.JobExecutionContext; 
import org.quartz.JobExecutionException;

import java.util.Date;

/** 
* <p> 
* This is just a simple job that says "Hello" to the world. 
* 一个简单的作业,来自Quartz的Simple Examples。 
* </p> 

* @author Bill Kratzer 
*/ 
public class HelloJob implements Job {

private static Log _log = LogFactory.getLog(HelloJob.class);

/** 
     * <p> 
     * Empty constructor for job initilization 
     * </p> 
     * <p> 
     * Quartz requires a public empty constructor so that the 
     * scheduler can instantiate the class whenever it needs. 
     * </p> 
     */ 
    public HelloJob() { 
    }

/** 
     * <p> 
     * Called by the <code>{@link org.quartz.Scheduler}</code> when a 
     * <code>{@link org.quartz.Trigger}</code> fires that is associated with 
     * the <code>Job</code>. 
     * </p> 
     * 
     * @throws JobExecutionException if there is an exception while executing the job. 
     */ 
    public void execute(JobExecutionContext context) 
            throws JobExecutionException {

// Say Hello to the World and display the date/time 
        _log.info("Hello World! - " + new Date()); 
    } 
}

 
运行结果:
2008-08-21 00:01:06  - INFO  org.quartz.examples.example1.SimpleExample     - ------- 初始化开始 ---------------------- 
2008-08-21 00:01:07  - INFO  org.quartz.simpl.SimpleThreadPool     - Job execution threads will use class loader of thread: main 
2008-08-21 00:01:07  - INFO  org.quartz.core.QuartzScheduler     - Quartz Scheduler v.1.6.0 created. 
2008-08-21 00:01:07  - INFO  org.quartz.simpl.RAMJobStore     - RAMJobStore initialized. 
2008-08-21 00:01:07  - INFO  org.quartz.impl.StdSchedulerFactory     - Quartz scheduler 'DefaultQuartzScheduler' initialized from default resource file in Quartz package: 'quartz.properties' 
2008-08-21 00:01:07  - INFO  org.quartz.impl.StdSchedulerFactory     - Quartz scheduler version: 1.6.0 
2008-08-21 00:01:07  - INFO  org.quartz.examples.example1.SimpleExample     - ------- 初始化完成 ----------- 
2008-08-21 00:01:07  - INFO  org.quartz.examples.example1.SimpleExample     - ------- 调度任务 ------------------- 
2008-08-21 00:01:07  - INFO  org.quartz.examples.example1.SimpleExample     - group1.job1 将在某时刻: Thu Aug 21 00:02:00 CST 2008 运行! 
2008-08-21 00:01:07  - INFO  org.quartz.core.QuartzScheduler     - Scheduler DefaultQuartzScheduler_$_NON_CLUSTERED started. 
2008-08-21 00:01:07  - INFO  org.quartz.examples.example1.SimpleExample     - ------- 已启动调度程序 ----------------- 
2008-08-21 00:01:07  - INFO  org.quartz.examples.example1.SimpleExample     - ------- 等待15秒... ------------- 
2008-08-21 00:01:09  - INFO  org.quartz.examples.example1.SimpleExample     - ------- 关闭调度程序开始 --------------------- 
2008-08-21 00:01:09  - INFO  org.quartz.core.QuartzScheduler     - Scheduler DefaultQuartzScheduler_$_NON_CLUSTERED shutting down. 
2008-08-21 00:01:09  - INFO  org.quartz.core.QuartzScheduler     - Scheduler DefaultQuartzScheduler_$_NON_CLUSTERED paused. 
2008-08-21 00:01:09  - INFO  org.quartz.simpl.SimpleThreadPool     - There are still 13 worker threads active. See javadoc runInThread(Runnable) for a possible explanation 
2008-08-21 00:01:09  - INFO  org.quartz.core.QuartzScheduler     - Scheduler DefaultQuartzScheduler_$_NON_CLUSTERED shutdown complete. 
2008-08-21 00:01:09  - INFO  org.quartz.examples.example1.SimpleExample     - ------- 关闭调度程序完成 -----------------

Process finished with exit code 0

 
注意:这个示例依赖jta.jar,还没仔细研究为什么要依赖这个包,不过这个包就在Quartz的发布包中,目前最新的releas版是1.60.

Quartz 任务调度(转)的更多相关文章

  1. 从零开始学 Java - Spring 使用 Quartz 任务调度定时器

    生活的味道 睁开眼看一看窗外的阳光,伸一个懒腰,拿起放在床一旁的水白开水,甜甜的味道,晃着尾巴东张西望的猫猫,在窗台上舞蹈.你向生活微笑,生活也向你微笑. 请你不要询问我的未来,这有些可笑.你问我你是 ...

  2. Quartz任务调度快速入门

    Quartz任务调度快速入门 概述 了解Quartz体系结构 Quartz对任务调度的领域问题进行了高度的抽象,提出了调度器.任务和触发器这3个核心的概念,并在org.quartz通过接口和类对重要的 ...

  3. Quartz任务调度

    狂神声明 : 文章均为自己的学习笔记 , 转载一定注明出处 ; 编辑不易 , 防君子不防小人~共勉 ! Quartz任务调度 课程目标 : 了解Quartz框架 : 任务(Job)  触发器(Trig ...

  4. Quartz任务调度实践

    最近在写一个任务调度程序,需要每隔几秒查询数据库,并取出数据做一些处理操作.使用到了Quartz任务调度框架. 基本概念 Quartz包含几个重要的对象,分别为任务(Job),触发器(Trigger) ...

  5. Quartz任务调度入门

    Quartz任务调度入门 了解Quartz体系结构Quartz对任务调度的领域问题进行了高度的抽象,提出了调度器.任务和触发器这3个核心的概念,并在org.quartz通过接口和类对重要的这些核心概念 ...

  6. Spring研磨分析、Quartz任务调度、Hibernate深入浅出系列文章笔记汇总

    Spring研磨分析.Quartz任务调度.Hibernate深入浅出系列文章笔记汇总 置顶2017年04月27日 10:46:45 阅读数:1213 这系列文章主要是对Spring.Quartz.H ...

  7. quartz任务调度初次使用记录

    近期公司开发的数据交换系统嵌入了quartz任务调度功能,大概了解了任务调度的整个流程,项目中需要用到它来进行定时任务操作,对数据定时检查以及及时交换. Quartz是OpenSymphony开源组织 ...

  8. (转)Quartz任务调度(1)概念例析快速入门

    http://blog.csdn.net/qwe6112071/article/details/50991563 Quartz框架需求引入 在现实开发中,我们常常会遇到需要系统在特定时刻完成特定任务的 ...

  9. Quartz任务调度 服务日志+log4net打印日志+制作windows服务

    引言 现在许多的项目都需要定时的服务进行支撑,而我们经常用到的定时服务就是Quartz任务调度了.不过我们在使用定时Job进行获取的时候,有时候我们就需要记录一下自定义的日志,甚至我们还会对执行定时J ...

  10. Quartz任务调度:MisFire策略和源码分析

    Quartz是为大家熟知的任务调度框架,先看看官网的介绍: ---------------------------------------------------------------------- ...

随机推荐

  1. [bzoj4592] [Shoi2015]脑洞治疗仪

    题面无法直视系列. 中规中矩的线段树题. 涉及的操作有:区间赋值为0,计算区间内1的个数,区间赋值为1,求区间内最大的连续的1的个数. #include<cstdio> #include& ...

  2. CodeForces-2015 HIAST Collegiate Programming Contest-Gym-100952A.水题 100952B.水题 100952C.回文字符串 100952D.杨辉三角处理组合数 其他题目待续。。。

    哈哈哈哈哈哈哈,最近一直在补题,改各种错误的代码,wa了20多遍,改到心态爆炸,改好之后,感觉世界都美好了(叉会腰~)... A. Who is the winner? time limit per ...

  3. 利用dfs解决规定路程问题

    今天继续dfs的训练,遇到了一道神题,不停地TLE,我DD都快碎了.....好在经过本渣不懈努力,还是弄了出来,不容易啊,发上来纪念一下,顺便总结一下关于用dfs解决规定路程的问题. 先上题目: De ...

  4. 最长上升子序列(LIS) dp学习~3

    题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=1087 Super Jumping! Jumping! Jumping! Time Limit: 200 ...

  5. 解决 重启nginx: [alert] kill(189, 1) failed (3: No such process)

    解决 nginx: [alert] kill(189, 1) failed (3: No such process) [root@localhost/]# nginx -s reloadnginx: ...

  6. 让BLE设备的名称包含MAC地址

    对于研发和测试BLE来说,经常看到同名的设备,是极为不方便的,一大堆设备同时上电会让同事不知道哪一个设备才是自己真正想操作的目标.再说一下小米手环,家中有三支小米手环,打开设备搜索全是“MI”,都不知 ...

  7. Android中与task相关的几个属性

    1.与任务相关的属性 taskAffinity :修改任何给定Activity的关联 系统使用包名标识应用的默认任务关联: taskAffinity属性取字符串值,必须不同于包名: taskAffin ...

  8. Django App(一) StartApp

    经过配置Pycharm在上一次的笔记中,已经解决了编写Django web程序调试的问题,这篇将记录Django官网提供的例子程序!          1.查看Pycharm terminal是否可用 ...

  9. Spark性能调优之资源分配

    Spark性能调优之资源分配    性能优化王道就是给更多资源!机器更多了,CPU更多了,内存更多了,性能和速度上的提升,是显而易见的.基本上,在一定范围之内,增加资源与性能的提升,是成正比的:写完了 ...

  10. 利用PHPExcel导出Excel并设置Excel格式以及数据源

    浏览:23969 发布日期:2013/07/24 分类:技术分享 代码有点长,读起来有点累.先来个截图 导出的Excel太宽了,所以将后面的列宽重新调整了再截的图 功能包括: 1.设置单元格格式,包括 ...