原创地址:http://www.cnblogs.com/Alandre/(泥沙砖瓦浆木匠),需要转载的,保留下!

弟子规 圣人训 首孝弟 次谨信 泛爱众 而亲仁 有余力 则学文

Written In The Font

需要:

  1. 导入WEB-INF/lib/quartz-2.2.1.jar
  2. 然后数据库建相关表格,可以去quartz-2.2.1\docs\dbTables目录下找到对应的数据库表格.(我这边Mysql , 导入 tables_mysql.sql 即可)
  3. 配置quartz.properties
    1. #============================================================================
    2. # Configure Main Scheduler Properties
    3. #============================================================================
    4. org.quartz.scheduler.instanceName: wmuitpScheduler
    5. org.quartz.scheduler.instanceId: AUTO
    6.  
    7. org.quartz.scheduler.skipUpdateCheck: true
    8.  
    9. #============================================================================
    10. # Configure ThreadPool
    11. #============================================================================
    12. org.quartz.threadPool.class: org.quartz.simpl.SimpleThreadPool
    13. org.quartz.threadPool.threadCount: 10
    14. org.quartz.threadPool.threadPriority: 5
    15. org.quartz.threadPool.threadsInheritContextClassLoaderOfInitializingThread = true
    16.  
    17. #============================================================================
    18. # Configure JobStore
    19. #============================================================================
    20.  
    21. org.quartz.jobStore.misfireThreshold: 60000
    22.  
    23. org.quartz.jobStore.class=org.quartz.impl.jdbcjobstore.JobStoreTX
    24. org.quartz.jobStore.driverDelegateClass=org.quartz.impl.jdbcjobstore.StdJDBCDelegate
    25. org.quartz.jobStore.useProperties=false
    26. org.quartz.jobStore.dataSource=myDS
    27. org.quartz.jobStore.tablePrefix=qrtz_
    28. org.quartz.jobStore.isClustered=true
    29.  
    30. #============================================================================
    31. # Configure Datasources
    32. #============================================================================
    33.  
    34. org.quartz.dataSource.myDS.driver: com.mysql.jdbc.Driver
    35. org.quartz.dataSource.myDS.URL: jdbc:mysql://localhost:3307/itp
    36. org.quartz.dataSource.myDS.user: root
    37. org.quartz.dataSource.myDS.password: 123456
    38. org.quartz.dataSource.myDS.maxConnections: 5
    39. org.quartz.dataSource.myDS.validationQuery: select 0

基本步骤:

web.xml注册监听器ScheduleStartListener

注册quartz监听器,监听项目是否启动或者重启.保证项目启动或重启时,所有任务会被重新安排到任务调度中.

web.xml添加一个Listener:

  1. <!-- quartz监听器 -->
  2. <listener>
  3. <listener-class>sedion.jeffli.wmuitp.listener.ScheduleStartListener</listener-class>
  4. </listener>

监听器类sedion.jeffli.wmuitp.listener.ScheduleStartListener实现

监听器类主要是实现recovery各个任务,重新恢复在triggerGroups组中所有的触发器,按新的trigger重新设置job执行.顺便说下,这个异常自定义(不需要删除即可): sedion.jeffli.wmuitp.exception.QuartzException;

  1. package sedion.jeffli.wmuitp.listener;
  2.  
  3. import java.util.List;
  4.  
  5. import javax.servlet.ServletContextEvent;
  6. import javax.servlet.ServletContextListener;
  7.  
  8. import org.quartz.Scheduler;
  9. import org.quartz.SchedulerFactory;
  10. import org.quartz.Trigger;
  11. import org.quartz.TriggerKey;
  12. import org.quartz.impl.StdSchedulerFactory;
  13.  
  14. import sedion.jeffli.wmuitp.exception.QuartzException;
  15.  
  16. public class ScheduleStartListener implements ServletContextListener
  17. {
  18.  
  19. public void contextDestroyed(ServletContextEvent sce)
  20. {
  21.  
  22. }
  23.  
  24. public void contextInitialized(ServletContextEvent sce)
  25. {
  26. try
  27. {
  28. recovery();
  29. }
  30. catch (Exception e)
  31. {
  32. throw new QuartzException(" ScheduleStartListener contextInitialized ERROR!!",e);
  33. }
  34. }
  35.  
  36. public void recovery()
  37. {
  38.  
  39. Scheduler scheduler = null;
  40.  
  41. try {
  42.  
  43. SchedulerFactory schedulerFactory = new StdSchedulerFactory();
  44. scheduler = schedulerFactory.getScheduler();//可以通过SchedulerFactory创建一个Scheduler实例
  45. List<String> triggerGroups = scheduler.getTriggerGroupNames();//获取调度器中所有的触发器组
  46. System.out.println("调度器中所有的触发器组 size():"+triggerGroups.size());
  47.  
  48. if(triggerGroups != null && triggerGroups.size() != 0)//重新恢复在triggerGroups组中所有的触发器
  49. {
  50. for (int i = 0; i < triggerGroups.size(); i++)
  51. {
  52. TriggerKey triggerKey = TriggerKey.triggerKey(triggerGroups.get(i), triggerGroups.get(i));
  53. System.out.println("triggerKey:"+triggerKey);
  54.  
  55. Trigger tg = scheduler.getTrigger(triggerKey);//获取trigger
  56. System.out.println(triggerKey+" -> 执行时间 :"+tg.getNextFireTime());
  57.  
  58. scheduler.rescheduleJob(triggerKey, tg);//按新的trigger重新设置job执行
  59. }
  60. }
  61.  
  62. scheduler.start();
  63.  
  64. }
  65. catch (Exception e)
  66. {
  67. throw new QuartzException("ScheduleStartListener recovery() Error!", e);
  68. }
  69. }
  70. }

测试案例第一步: Job 接口实现类JobTest

顾名思义,用于自定义任务,方法的实现.你可以在其中写入任意你想要在那个点上干的事情(操作数据库,前台显示等).在下面那处地方写入你想要写的:System.out.println("添入需要加入任务的具体操作"); .顺便说下,这个异常自定义(不需要删除即可):

  1. package test.quartz;
  2.  
  3. import org.quartz.Job;
  4. import org.quartz.JobDataMap;
  5. import org.quartz.JobExecutionContext;
  6. import org.quartz.JobExecutionException;
  7. import org.quartz.JobKey;
  8. import org.quartz.Scheduler;
  9. import org.quartz.SchedulerException;
  10. import org.quartz.SchedulerFactory;
  11. import org.quartz.TriggerKey;
  12. import org.quartz.impl.StdSchedulerFactory;
  13.  
  14. import sedion.jeffli.wmuitp.exception.QuartzException;
  15.  
  16. public class JobTest implements Job{
  17.  
  18. public JobTest() {}
  19.  
  20. public void execute(JobExecutionContext context)throws JobExecutionException
  21. {
  22.  
  23. JobDataMap data = context.getJobDetail().getJobDataMap();
  24. System.out.println("data.testId : "+data.getInt("testId")); //不需要可删除
  25.  
  26. try
  27. {
  28. System.out.println("添入需要加入任务的具体操作");
  29. }
  30. catch (Exception e)
  31. {
  32. throw new QuartzException("JobTest execute() ERROR !!", e);
  33. }
  34. }
  35.  
  36. public static void removeJob(JobKey jobKey, TriggerKey tiKey)throws SchedulerException
  37. {
  38.  
  39. SchedulerFactory sf = new StdSchedulerFactory();
  40. Scheduler sched = sf.getScheduler();
  41.  
  42. sched.pauseTrigger(tiKey); //停止触发器
  43. sched.unscheduleJob(tiKey); //移除触发器
  44. sched.deleteJob(jobKey); //删除任务
  45.  
  46. }
  47. }

测试案例第二步:QuartzTest

顾名思义,用于实现,检验.可以通过SchedulerFactory创建一个Scheduler实例,把触发器在集群节点实例命名的组只是为了区分(伐木)从什么地方定问调度重新执行此作业,如果它是正在进行时调度下去.

  1. package test.quartz;
  2.  
  3. import static org.quartz.JobBuilder.newJob;
  4. import static org.quartz.TriggerBuilder.newTrigger;
  5.  
  6. import java.util.Date;
  7.  
  8. import org.quartz.JobDetail;
  9. import org.quartz.Scheduler;
  10. import org.quartz.SchedulerFactory;
  11. import org.quartz.SimpleTrigger;
  12. import org.quartz.impl.StdSchedulerFactory;
  13.  
  14. public class QuartzTest
  15. {
  16.  
  17. public void run(String date, int id)throws Exception
  18. {
  19.  
  20. SchedulerFactory schedulerFactory = new StdSchedulerFactory();
  21. Scheduler scheduler = schedulerFactory.getScheduler();//可以通过SchedulerFactory创建一个Scheduler实例
  22.  
  23. //设置工作详情
  24. JobDetail job = newJob(JobTest.class)
  25. .withIdentity("job_"+id, "test"+id) // (String name, String group)把触发器在集群节点实例命名的组只是为了区分(伐木)从什么地方定问调度重新执行此作业,如果它是正在进行时调度下去...
  26. .requestRecovery()
  27. .build();
  28.  
  29. job.getJobDataMap().put("testId", id); //设置存储参数(不需要可删除)
  30.  
  31. Date startDate = FormatDate.stringToDateAll(date);//Date转String
  32. //设置触发器
  33. SimpleTrigger trigger = (SimpleTrigger) newTrigger()
  34. .withIdentity("overdue"+id, "overdue"+id)//withIdentity("trigger", "group")
  35. .startAt(startDate)
  36. .build();
  37.  
  38. scheduler.scheduleJob(job, trigger);
  39. scheduler.start();
  40. System.out.println("------- Start Scheduler ----------------");
  41. }
  42.  
  43. public static void main(String[] args) throws Exception
  44. {
  45. QuartzTest quartzOverdue = new QuartzTest();
  46. quartzOverdue.run("2014-07-02 00:30:00",666);//666,随便的吉祥数字
  47. }
  48. }

这边,项目tomcat启动.这边我的主机时间是:

然后我们运行:

  1. public static void main(String[] args) throws Exception
  2. {
  3. QuartzTest quartzOverdue = new QuartzTest();
  4. quartzOverdue.run("2014-07-02 00:30:00",666);//666,随便的吉祥数字
  5. }

看控制台:

先输出

  1. ------- Start Scheduler ----------------

然后时间到了

  1. 添入需要加入任务的具体操作

然后测试 quartz的持久化.(持久化测试就是 先开启任务,然后 中间断开重启服务器),之间你会发现控制台:

今天我重写了下,:

  1. public static void main(String[] args) throws Exception
  2. {
  3. QuartzTest quartzOverdue = new QuartzTest();
  4. quartzOverdue.run("2014-07-02 10:00:00",6666);
  5. }
  1. 调度器中所有的触发器组 size():1
  2. triggerKey:test6666.test6666
  3. test6666.test6666 -> 执行时间 :Wed Jul 02 10:00:00 CST 2014

项目ITP(七) javaWeb 整合 Quartz 实现动态调度 并且 持久化的更多相关文章

  1. 项目ITP(七) javaWeb 整合 Quartz 实现动态调度 而且 持久化

    版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/u010378410/article/details/36255511 项目ITP(七) javaWe ...

  2. 项目ITP(四) javaweb http json 交互 in action (服务端 spring 手机端 提供各种工具类)勿喷!

    前言 系列文章:[传送门] 洗了个澡,准备写篇博客.然后看书了.时间 3 7 分.我慢慢规律生活,向目标靠近.  很喜欢珍惜时间像叮当猫一样 正文 慢慢地,二维码实现签到将要落幕了.下篇文章出二维码实 ...

  3. 项目ITP(六) spring4.0 整合 Quartz 实现动态任务调度

    前言 系列文章:[传送门] 项目需求: http://www.cnblogs.com/Alandre/p/3733249.html 上一博客写的是基本调度,后来这只能用于,像每天定个时间 进行数据库备 ...

  4. 项目ITP(五) spring4.0 整合 Quartz 实现任务调度

    前言 系列文章:[传送门] 项目需求: 二维码推送到一体机上,给学生签到扫描用.然后需要的是 上课前20分钟 ,幸好在帮带我的学长做 p2p 的时候,接触过.自然 quartz 是首选.所以我就配置了 ...

  5. SSM项目整合Quartz

    一.背景 SSM项目中要用到定时器,初期使用Timer,后来用spring 的schedule,都比较简单,所以功能比较单一而且他们不能动态的配置时间.后来就研究quartz,准备整合到项目中.Qua ...

  6. 初识quartz 并分析 项目中spring整合quartz的配置【原创+转载】

    初识quartz 并分析 项目中spring整合quartz的配置[原创+转载]2018年01月29日 12:08:07 守望dfdfdf 阅读数:114 标签: quartz 更多个人分类: 工具 ...

  7. Spring 3整合Quartz 2实现手动设置定时任务:新增,修改,删除,暂停和恢复(附带源码)

    摘要:在项目的管理功能中,对定时任务的管理有时会很常见.但一般定时任务配置都在xml中完成,包括cronExpression表达式,十分的方便.但是如果我的任务信息是保存在数据库的,想要动态的初始化, ...

  8. 【淘淘】Spring整合Quartz框架

    我在外面工作实习的时候,我们做的项目是一个日报子系统,也就是定时定点为公司生成一些报表数据还有一些数据反馈.这时候我们会经常用到定时任务,比如每天凌晨生成前天报表,每一小时生成汇总数据等等.当时,我做 ...

  9. Spring整合Quartz实现持久化、动态设定时间

    一.spring整合 网上一搜有很多整合的方式,这里我采用了其中的一种(暂时还没有对其他的方法研究过). 对于spring的整合其中的任务,spring提供了几个类.接口(这些类都实现了Job接口): ...

随机推荐

  1. pyc文件

    1.pyc文件 是python预编译后的字节码文件,并不是机器码.2.PyCodeObject 是Python编译器真正编译成的结果: 当python程序运行时,编译的结果是保存在PyCodeObje ...

  2. java中如何使用break跳出多重循环

    java 中已知的三种跳出多重循环的方式: System.out.println("---------java中跳出多重循环的三种方式:---------"); System.ou ...

  3. mysql 统计某个月每天的数据

    select SUM(order_money) as money,substr(t.pay_time,1,10) as time  from pay_log t where  t.pay_time l ...

  4. rn下的弹性布局

    重点: 1]react native 下的弹性布局名字叫:flexDirection 2]flexDirection的默认值是column而不是row,而flex也只能指定一个数字值. 3]使用fle ...

  5. CentOS7配置阿里云源

    cd /etc/yum.repos.d/ mkdir backup mv CentOS-* backup/ wget -O /etc/yum.repos.d/CentOS-Base.repo http ...

  6. mongodb聚合操作

    1. mongodb的聚合是什么 聚合(aggregate)是基于数据处理的聚合管道,每个文档通过一个由多个阶段(stage)组成的管道,可以对每个阶段的管道进行分组.过滤等功能,然后经过一系列的处理 ...

  7. Leetcode(二)两数相加

    两数相加 题目描述 给出两个非空的链表用来表示两个非负的整数.其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字. 如果,我们将这两个数相加起来,则会返回一个新的链 ...

  8. Email发展历史

    据我所知:1987年9月20日,有“中国互联网第一人”之称的钱天白从北京经意大利向前联邦德国卡尔斯鲁厄大学发出了中国第一封电子邮件,内容是“ 穿越长城,走向世界”.这是中国人在网络上的第一步,他开创了 ...

  9. 利用python完成大学刷课(从0到完成的思路)

    i春秋作家:tllm 原文来自:利用python完成大学刷课(从0到完成的思路) 最近刚刚开学,学校总是有很多让人无语的课要修,还不能不修.然后我想写一个自动修课的脚本.大佬们不要笑我 是边面向百度学 ...

  10. git知识整理

    概述 工作中使用git进行代码托管,一开始只知道git add commit,之后了解了git-flow插件,觉得超牛逼,一键生成feature分支,再后来听说原生git命令更好用,于是又去学了原生g ...