要学习Quartz框架,首先大概了解了Quartz的基本知识后,在通过简单的例子入门,一步一个脚印的走下去。

下面介绍Quartz入门的示例,由于Quartz的存储方式分为RAM和JDBC,分别对这两种进行简单的说明。并附上代码!

首先需要添加Quartz的Jar包 ,我使用的是quartz.2.2.1版本!

Demo代码下载地址:quartz_demo

  1. <!-- quartz -->
  2. <dependency>
  3. <groupId>org.quartz-scheduler</groupId>
  4. <artifactId>quartz</artifactId>
  5. <version>2.2.1</version>
  6. </dependency>
  7. <dependency>
  8. <groupId>org.quartz-scheduler</groupId>
  9. <artifactId>quartz-jobs</artifactId>
  10. <version>2.2.1</version>
  11. </dependency>

1:RAM方式

要测试RAMdemo的代码,请先删除demo中这个quartz.properties文件,或者重命名!否则会测试不成功!

(1):Job

  1. package com.dufy.learn;
  2. import java.util.Date;
  3. import org.quartz.Job;
  4. import org.quartz.JobExecutionContext;
  5. import org.quartz.JobExecutionException;
  6. import org.slf4j.Logger;
  7. import org.slf4j.LoggerFactory;
  8. public class RAMJob implements Job{
  9. private static Logger _log = LoggerFactory.getLogger(RAMJob.class);
  10. @Override
  11. public void execute(JobExecutionContext arg0) throws JobExecutionException {
  12. _log.info("Say hello to Quartz" + new Date());
  13. }
  14. }

(2):QuartzTest

  1. package com.dufy.learn;
  2. import java.util.Date;
  3. import org.quartz.CronScheduleBuilder;
  4. import org.quartz.JobBuilder;
  5. import org.quartz.JobDetail;
  6. import org.quartz.Scheduler;
  7. import org.quartz.SchedulerException;
  8. import org.quartz.SchedulerFactory;
  9. import org.quartz.SimpleScheduleBuilder;
  10. import org.quartz.Trigger;
  11. import org.quartz.TriggerBuilder;
  12. import org.quartz.impl.StdSchedulerFactory;
  13. import org.slf4j.Logger;
  14. import org.slf4j.LoggerFactory;
  15. /**
  16. * This is a RAM Store Quartz!
  17. * @author dufy
  18. * @date 2017.02.04
  19. *
  20. */
  21. public class RAMQuartz {
  22. private static Logger _log = LoggerFactory.getLogger(RAMQuartz.class);
  23. public static void main(String[] args) throws SchedulerException {
  24. //1.创建Scheduler的工厂
  25. SchedulerFactory sf = new StdSchedulerFactory();
  26. //2.从工厂中获取调度器实例
  27. Scheduler scheduler = sf.getScheduler();
  28. //3.创建JobDetail
  29. JobDetail jb = JobBuilder.newJob(RAMJob.class)
  30. .withDescription("this is a ram job") //job的描述
  31. .withIdentity("ramJob", "ramGroup") //job 的name和group
  32. .build();
  33. //任务运行的时间,SimpleSchedle类型触发器有效
  34. long time= System.currentTimeMillis() + 3*1000L; //3秒后启动任务
  35. Date statTime = new Date(time);
  36. //4.创建Trigger
  37. //使用SimpleScheduleBuilder或者CronScheduleBuilder
  38. Trigger t = TriggerBuilder.newTrigger()
  39. .withDescription("")
  40. .withIdentity("ramTrigger", "ramTriggerGroup")
  41. //.withSchedule(SimpleScheduleBuilder.simpleSchedule())
  42. .startAt(statTime) //默认当前时间启动
  43. .withSchedule(CronScheduleBuilder.cronSchedule("0/2 * * * * ?")) //两秒执行一次
  44. .build();
  45. //5.注册任务和定时器
  46. scheduler.scheduleJob(jb, t);
  47. //6.启动 调度器
  48. scheduler.start();
  49. _log.info("启动时间 : " + new Date());
  50. }
  51. }

运行结果:

SimpleScheduleBuilder:

CronScheduleBuilder:

2.JDBC方式

使用jdbc方式,就要配置quartz.properties文件,并且在开始的时候在数据库中新增表!

我使用的数据库是mysql,数据库中表在quartz_demo里面有,需要的请在里面下载!

运行 tables_db2_v8.sql 这个文件。

  1. #JDBC驱动
  2. org.quartz.dataSource.qzDS.driver:com.mysql.jdbc.Driver
  3. org.quartz.dataSource.qzDS.URL:jdbc:mysql://localhost:3306/quartz_test
  4. org.quartz.dataSource.qzDS.user:root
  5. org.quartz.dataSource.qzDS.password:root
  6. org.quartz.dataSource.qzDS.maxConnection:10

(1)MyJob

  1. package com.dufy.jdbctest;
  2. import java.text.SimpleDateFormat;
  3. import java.util.Date;
  4. import org.quartz.Job;
  5. import org.quartz.JobExecutionContext;
  6. import org.quartz.JobExecutionException;
  7. import org.slf4j.Logger;
  8. import org.slf4j.LoggerFactory;
  9. public class MyJob implements Job{
  10. private static final Logger log = LoggerFactory.getLogger(MyJob.class);
  11. @Override
  12. public void execute(JobExecutionContext context)throws JobExecutionException {
  13. log.info("MyJob is start ..................");
  14. log.info("Hello quzrtz "+
  15. new SimpleDateFormat("yyyy-MM-dd HH:mm:ss ").format(new Date()));
  16. log.info("MyJob is end .....................");
  17. }
  18. }

(2)QuartzJdbcTest

  1. package com.dufy.jdbctest;
  2. import java.text.ParseException;
  3. import java.util.List;
  4. import org.quartz.CronScheduleBuilder;
  5. import org.quartz.CronTrigger;
  6. import org.quartz.JobBuilder;
  7. import org.quartz.JobDetail;
  8. import org.quartz.JobKey;
  9. import org.quartz.Scheduler;
  10. import org.quartz.SchedulerException;
  11. import org.quartz.SchedulerFactory;
  12. import org.quartz.SimpleScheduleBuilder;
  13. import org.quartz.SimpleTrigger;
  14. import org.quartz.Trigger;
  15. import org.quartz.TriggerBuilder;
  16. import org.quartz.TriggerKey;
  17. import org.quartz.impl.StdSchedulerFactory;
  18. public class QuartzJdbcTest {
  19. public static void main(String[] args) throws SchedulerException,
  20. ParseException {
  21. startSchedule();
  22. //resumeJob();
  23. }
  24. /**
  25. * 开始一个simpleSchedule()调度
  26. */
  27. public static void startSchedule() {
  28. try {
  29. // 1、创建一个JobDetail实例,指定Quartz
  30. JobDetail jobDetail = JobBuilder.newJob(MyJob.class)
  31. // 任务执行类
  32. .withIdentity("job1_1", "jGroup1")
  33. // 任务名,任务组
  34. .build();
  35. //触发器类型
  36. SimpleScheduleBuilder builder = SimpleScheduleBuilder
  37. // 设置执行次数
  38. .repeatSecondlyForTotalCount(5);
  39. //CronScheduleBuilder builder = CronScheduleBuilder.cronSchedule("0/2 * * * * ?");
  40. // 2、创建Trigger
  41. Trigger trigger = TriggerBuilder.newTrigger()
  42. .withIdentity("trigger1_1", "tGroup1").startNow()
  43. .withSchedule(builder)
  44. .build();
  45. // 3、创建Scheduler
  46. Scheduler scheduler = StdSchedulerFactory.getDefaultScheduler();
  47. scheduler.start();
  48. // 4、调度执行
  49. scheduler.scheduleJob(jobDetail, trigger);
  50. try {
  51. Thread.sleep(60000);
  52. } catch (InterruptedException e) {
  53. e.printStackTrace();
  54. }
  55. //关闭调度器
  56. scheduler.shutdown();
  57. } catch (SchedulerException e) {
  58. e.printStackTrace();
  59. }
  60. }
  61. /**
  62. * 从数据库中找到已经存在的job,并重新开户调度
  63. */
  64. public static void resumeJob() {
  65. try {
  66. SchedulerFactory schedulerFactory = new StdSchedulerFactory();
  67. Scheduler scheduler = schedulerFactory.getScheduler();
  68. JobKey jobKey = new JobKey("job1_1", "jGroup1");
  69. List<? extends Trigger> triggers = scheduler.getTriggersOfJob(jobKey);
  70. //SELECT TRIGGER_NAME, TRIGGER_GROUP FROM {0}TRIGGERS WHERE SCHED_NAME = {1} AND JOB_NAME = ? AND JOB_GROUP = ?
  71. // 重新恢复在jGroup1组中,名为job1_1的 job的触发器运行
  72. if(triggers.size() > 0){
  73. for (Trigger tg : triggers) {
  74. // 根据类型判断
  75. if ((tg instanceof CronTrigger) || (tg instanceof SimpleTrigger)) {
  76. // 恢复job运行
  77. scheduler.resumeJob(jobKey);
  78. }
  79. }
  80. scheduler.start();
  81. }
  82. } catch (Exception e) {
  83. e.printStackTrace();
  84. }
  85. }
  86. }

运行结果:

控制台打印:

Cron和Simple类型,Simple类型的如果JobDetail没有设置.storeDurably(true),则job在运行完成之后会在数据库中删除!


欢迎访问我的csdn博客,我们一同成长!

"不管做什么,只要坚持下去就会看到不一样!在路上,不卑不亢!"

博客首页:http://blog.csdn.net/u010648555

Quartz学习——Quartz简单入门Demo(二)的更多相关文章

  1. Quartz学习-- quartz基本介绍和 Cron表达式

    Quartz学习 一. Quartz 大致简介 Quartz 是完全由 java 开发的一个开源的任务日程管理系统 ​任务日程管理系统 换句话说就是: ​ 一个预先确定的日程时间到达时,负责执行任务的 ...

  2. Quartz学习——Quartz大致介绍(一)

    1. 介绍 Quartz是OpenSymphony开源组织在Job scheduling领域又一个开源项目,是完全由java开发的一个开源的任务日程管理系统,"任务进度管理器"就是 ...

  3. Quartz学习——Quartz大致介绍 转

    转自阿飞先生 http://blog.csdn.net/u010648555/article/details/54863144 1. 介绍 Quartz是OpenSymphony开源组织在Job sc ...

  4. dubbo入门学习笔记之入门demo(基于普通maven项目)

    注:本笔记接dubbo入门学习笔记之环境准备继续记录; (四)开发服务提供者和消费者并让他们在启动时分别向注册中心注册和订阅服务 需求:订单服务中初始化订单功能需要调用用户服务的获取用户信息的接口(订 ...

  5. gflag的简单入门demo

    gflags 一. 下载与安装 这里直接使用包管理器安装: sudo apt install libgflags-dev 二. gflags的简单使用 1. 定义需要的类型 格式: DEFINE_类型 ...

  6. 第二篇:docker 简单入门(二)

    本篇目录 写在最前面的话 最常用的docker命令 获取远程仓库镜像 写在最前面的话 如上图大家看到的这样,以后此类文章请到其他平台查阅,由于博客园提示说,内容太多简单,所以以后简单的内容我会放在cs ...

  7. 【VB超简单入门】二、知识准备

    在开始编程之前,需要先熟悉一下各种操作和术语,以后学习编程才能得心应手. 首先最重要的操作当然就是-电脑的开机关机啦~(开个玩笑哈哈),必须掌握软件的安装和卸载,还有能编写批处理程序对平时的使用也是很 ...

  8. 安卓学习-- RecyclerView简单入门

    一.加入JAR包 第一感觉这个东东,好复杂,没ListView来的快,方便 在项目中加入android-support-v7-recyclerview.jar包 这个包在extras\android\ ...

  9. 深入浅出Tabhost+简单入门Demo

    小伙伴们在手机上逛淘宝的时候,会发现在淘宝的下面有个按钮,分别是首页.微淘.社区.购物车和我的淘宝,点击不同的按钮会跳转到不同的页面,目前小编所接手的这个项目,也需要用到类似这样的功能,小编就发挥网络 ...

随机推荐

  1. Jmeter常用功能详解

    嘻嘻,忙碌的一周,马上就到周四了~明天就是周五了,可以去嗨了! 这几天正式成立了一个微信订阅号,旨在免费帮助需要入门软件测试的小白! 各位走过路过的亲,欢迎订阅哦:扫描二维码即可订阅

  2. 斐波那契数列—Java

    斐波那契数列想必大家都知道吧,如果不知道的话,我就再啰嗦一遍, 斐波那契数列为:1 2 3 5 8 13 ...,也就是除了第一项和第二项为1以外,对于第N项,有f(N)=f(N-1)+f(N-2). ...

  3. NOSQL EYE开源

    简介 NOSQL数据库监控工具,目前实现了对Redis.MongoDB的监控功能. 功能列表 演示地址 http://106.14.181.95:7004  登录用户名.密码:admin/admin ...

  4. h5video标签

    在video标签中,我们可以使用属性:videoWidth & videoHeight,它获取的是video的宽度和高度(媒体本身).虽然不能直接使用,但是可以通过计算宽高比得到 video ...

  5. [js高手之路]深入浅出webpack教程系列8-(postcss-loader,autoprefixer,html-loader,less-loader,ejs-loader)用法

    我们接着上文,那么在上篇文章的最后,写到了css-loader的用法,如果你用心发现,就能看到我在style.css样式文件中写了一个这样的样式: div { transition: all ease ...

  6. Eslint配置

    //ESLint 4.5.0,参考了eslint官方以及alloyteam团队配置 module.exports = { parser: 'babel-eslint', parserOptions: ...

  7. 验证Oracle收集统计信息参数granularity数据分析的力度

    最近在学习Oracle的统计信息这一块,收集统计信息的方法如下: DBMS_STATS.GATHER_TABLE_STATS ( ownname VARCHAR2, ---所有者名字 tabname ...

  8. cmake命令收集

    cmake中一些预定义变量 PROJECT_SOURCE_DIR 工程的根目录 PROJECT_BINARY_DIR 运行cmake命令的目录,通常是${PROJECT_SOURCE_DIR}/bui ...

  9. 201521123088《JAVA程序设计》第8周学习总结

    1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结集合与泛型相关内容. 1.2 选做:收集你认为有用的代码片段 2. 书面作业 本次作业题集集合 1.List中指定元素的删除(题目4 ...

  10. 201521123012 《Java程序设计》第六周学习总结

    ##1. 本周学习总结 1.1 面向对象学习暂告一段落,请使用思维导图,以封装.继承.多态为核心概念画一张思维导图,对面向对象思想进行一个总结. -注1:关键词与内容不求多,但概念之间的联系要清晰,内 ...