一、 说明

由于最近工作要实现定时任务的执行,而且要求定时周期是不固定的,所以就用到了quartz来实现这个功能;

spring3.1以下的版本必须使用quartz1.x系列,3.1以上的版本才支持quartz 2.x,不然会出错。至于原因,则是spring对于quartz的支持实现,org.springframework.scheduling.quartz.CronTriggerBean继承了org.quartz.CronTrigger,在quartz1.x系列中org.quartz.CronTrigger是个类,而在quartz2.x系列中org.quartz.CronTrigger变成了接口,从而造成无法用spring的方式配置quartz的触发器(trigger)。

我使用的quartz版本是2.2.1 。

最终实现的功能:

1) 项目启动时,可执行的定时任务启动,按时执行相应的逻辑 ;

2)  可添加新任务,删除任务,更新任务,暂停任务,恢复任务 ;

二、 添加quartz包

我使用Gradle构建项目,加包时只需下面一行即可:

compile "org.quartz-scheduler:quartz:2.2.1"

三、 配置及使用

1.  配置任务调度器 (对应的文件名为quartz-task.xml)

<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd"  default-lazy-init="false">  <!-- 调度器 -->     <bean name="schedulerFactoryBean" class="org.springframework.scheduling.quartz.SchedulerFactoryBean">         <!-- 通过applicationContextSchedulerContextKey属性配置spring上下文 -->             <property name="applicationContextSchedulerContextKey">                 <value>applicationContext</value>             </property>        </bean>       <!--加载可执行的任务-->     <bean id="loadTask" class="com.quartz.LoadTask" init-method="initTask" /> </beans>

2. 服务器启动时加载,在web.xml文件里配置

<context-param>   <param-name>contextConfigLocation</param-name>   <param-value>classpath:quartz-task.xml</param-value>  </context-param>

3. 加载可执行任务的类LoadTask.java

public class LoadTask {public void initTask() throws Exception {   Scheduler scheduler = schedulerFactoryBean.getScheduler();   // 可执行的任务列表   Collection<Task> taskList = taskService.findTask();   for (Task task : taskList) {    // 任务名称和任务组设置规则:    // 名称:task_1 ..    // 组 :group_1 ..    TriggerKey triggerKey = TriggerKey.triggerKey(      "task_" + task.getId(), "group_" + task.getId());    CronTrigger trigger = (CronTrigger) scheduler      .getTrigger(triggerKey);    // 不存在,创建一个    if (null == trigger) {     JobDetail jobDetail = JobBuilder       .newJob(QuartzJobFactory.class)       .withIdentity("task_" + task.getId(),         "group_" + task.getId()).build();     jobDetail.getJobDataMap().put("scheduleJob", task);     // 表达式调度构建器     CronScheduleBuilder scheduleBuilder = CronScheduleBuilder       .cronSchedule(getCronExpression());     // 按新的表达式构建一个新的trigger     trigger = TriggerBuilder       .newTrigger()       .withIdentity("task_" + task.getId(),         "group_" + task.getId())       .withSchedule(scheduleBuilder).build();     scheduler.scheduleJob(jobDetail, trigger);    } else {     // trigger已存在,则更新相应的定时设置     CronScheduleBuilder scheduleBuilder = CronScheduleBuilder       .cronSchedule(taskService.getCronExpression());     // 按新的cronExpression表达式重新构建trigger     trigger = trigger.getTriggerBuilder().withIdentity(triggerKey)       .withSchedule(scheduleBuilder).build();     // 按新的trigger重新设置job执行     scheduler.rescheduleJob(triggerKey, trigger);    }   }  }  @Autowired  private SchedulerFactoryBean schedulerFactoryBean;  @Autowired  private  TaskService taskService; }

4. 调度任务的入口

public class QuartzTaskFactory implements Job {    @Override  public void execute(JobExecutionContext context)    throws JobExecutionException {   // TODO Auto-generated method stub   try {    System.out.println("任务运行...");    Task task = (Task) context.getMergedJobDataMap().get(      "scheduleJob");    System.out.println("任务名称: [" + task.getTaskName() + "]");    //在这里执行你的任务...    } catch (Exception e) {    e.printStackTrace();   }  } }

5. 暂停任务

Scheduler scheduler = schedulerFactoryBean.getScheduler();
JobKey jobKey = JobKey.jobKey(scheduleJob.getJobName(), scheduleJob.getJobGroup());
scheduler.pauseJob(jobKey);

6. 恢复任务

Scheduler scheduler = schedulerFactoryBean.getScheduler();
JobKey jobKey = JobKey.jobKey(scheduleJob.getJobName(), scheduleJob.getJobGroup());
scheduler.resumeJob(jobKey);

7. 删除任务

Scheduler scheduler = schedulerFactoryBean.getScheduler();
JobKey jobKey = JobKey.jobKey(scheduleJob.getJobName(), scheduleJob.getJobGroup());
scheduler.deleteJob(jobKey);

8. 立即运行任务

Scheduler scheduler = schedulerFactoryBean.getScheduler();
JobKey jobKey = JobKey.jobKey(scheduleJob.getJobName(), scheduleJob.getJobGroup());
scheduler.triggerJob(jobKey);

9. 更新任务(时间表达式)

Scheduler scheduler = schedulerFactoryBean.getScheduler();TriggerKey triggerKey = TriggerKey.triggerKey(scheduleJob.getJobName(),
scheduleJob.getJobGroup());//获取trigger,即在spring配置文件中定义的 bean id="myTrigger"
CronTrigger trigger = (CronTrigger) scheduler.getTrigger(triggerKey);//表达式调度构建器
CronScheduleBuilder scheduleBuilder = CronScheduleBuilder.cronSchedule(scheduleJob
.getCronExpression());//按新的cronExpression表达式重新构建trigger
trigger = trigger.getTriggerBuilder().withIdentity(triggerKey)
.withSchedule(scheduleBuilder).build();//按新的trigger重新设置job执行 scheduler.rescheduleJob(triggerKey, trigger);

四、时间表达式说明

字段 允许值 允许的特殊字符

秒 0-59 , – * /

分 0-59 , – * /

小时 0-23 , – * /

日期 1-31 , – * ? / L W C

月份 1-12 或者 JAN-DEC , – * /

星期 1-7 或者 SUN-SAT , – * ? / L C #

年(可选) 留空, 1970-2099 , – * /

表达式意义

"0 0 12 * * ?" 每天中午12点触发

"0 15 10 ? * *" 每天上午10:15触发

"0 15 10 * * ?" 每天上午10:15触发

"0 15 10 * * ? *" 每天上午10:15触发

"0 15 10 * * ? 2005" 2005年的每天上午10:15触发

"0 * 14 * * ?" 在每天下午2点到下午2:59期间的每1分钟触发

"0 0/5 14 * * ?" 在每天下午2点到下午2:55期间的每5分钟触发

"0 0/5 14,18 * * ?" 在每天下午2点到2:55期间和下午6点到6:55期间的每5分钟触发

"0 0-5 14 * * ?" 在每天下午2点到下午2:05期间的每1分钟触发

"0 10,44 14 ? 3 WED" 每年三月的星期三的下午2:10和2:44触发

"0 15 10 ? * MON-FRI" 周一至周五的上午10:15触发

"0 15 10 15 * ?" 每月15日上午10:15触发

"0 15 10 L * ?" 每月最后一日的上午10:15触发

"0 15 10 ? * 6L" 每月的最后一个星期五上午10:15触发

"0 15 10 ? * 6L 2002-2005" 2002年至2005年的每月的最后一个星期五上午10:15触发

"0 15 10 ? * 6#3" 每月的第三个星期五上午10:15触发

每天早上6点

0 6 * * *

每两个小时

0 */2 * * *

晚上11点到早上8点之间每两个小时,早上八点

0 23-7/2,8 * * *

每个月的4号和每个礼拜的礼拜一到礼拜三的早上11点

0 11 4 * 1-3

1月1日早上4点

0 4 1 1 *

ok,定时任务已经正确执行....

我是看了这篇文章,http://www.meiriyouke.net/?p=140 ,写的很好。

Quartz实现动态定时任务相关推荐

  1. java 定时任务插件_详解Spring整合Quartz实现动态定时任务

    最近项目中需要用到定时任务的功能,虽然spring 也自带了一个轻量级的定时任务实现,但感觉不够灵活,功能也不够强大.在考虑之后,决定整合更为专业的Quartz来实现定时任务功能. 普通定时任务 首先 ...

  2. quartz SpringMvc 动态定时任务(quartz2.2)

    java自带定时任务可以解决部分问题但是当我们要动态执行定时任务时,quartz可以帮助我们有效解决这类型问题 代码亲测可用 springmvc中配置注入调度器scheduler,调用定时任务 < ...

  3. springboot和quartz整合实现动态定时任务(持久化单节点)

    Quartz是一个完全由java编写的开源作业调度框架,为在Java应用程序中进行作业调度提供了简单却强大的机制,它支持定时任务持久化到数据库,从而避免了重启服务器时任务丢失,支持分布式多节点,大大的 ...

  4. Quartz在Spring中设置动态定时任务 .

    什么是动态定时任务: 是由客户制定生成的,服务端只知道该去执行什么任务,但任务的定时是不确定的(是由客户制定).这样总不能修改配置文件每定制个定时任务就增加一个trigger吧,即便允许客户修改配置文 ...

  5. Quartz在Spring中动态设置cronExpression (spring设置动态定时任务)

    2019独角兽企业重金招聘Python工程师标准>>> 什么是动态定时任务:是由客户制定生成的,服务端只知道该去执行什么任务,但任务的定时是不确定的(是由客户制定). 这样总不能修改 ...

  6. java quartz 动态执行,浅谈SpringBoot集成Quartz动态定时任务

    SpringBoot自带schedule 沿用的springboot少xml配置的优良传统,本身支持表达式等多种定时任务 注意在程序启动的时候加上@EnableScheduling @Schedule ...

  7. Spring 3整合Quartz 2实现定时任务--转

    常规整合 http://www.meiriyouke.net/?p=82 最近工作中需要用到定时任务的功能,虽然Spring3也自带了一个轻量级的定时任务实现,但感觉不够灵活,功能也不够强大.在考虑之 ...

  8. springboot quartz 动态配置_springboot集成quartz实现动态任务调度

    quartz是一个开源的作业调度框架,本文就是介绍下springboot框架下继承quartz的一些使用示例 首先我们需要添加quartz的spring-boot-starter-quartz依赖 o ...

  9. Spring 3整合Quartz 2实现定时任务(转)

    http://www.meiriyouke.net/?p=82 最近工作中需要用到定时任务的功能,虽然Spring3也自带了一个轻量级的定时任务实现,但感觉不够灵活,功能也不够强大.在考虑之后,决定整 ...

最新文章

  1. Linux/docker下oracle开启监听,开启自动启动
  2. Android下 scrollview的滚动停止事件的监听方法
  3. 【数据结构与算法】之深入解析“二叉树的后序遍历”的求解思路与算法示例
  4. 自己实现多线程的socket,socketserver源码剖析
  5. 思维修炼之 第三种选择
  6. NLP之---word2vec算法skip-gram原理详解
  7. CSDN中使用编辑器空格
  8. 传智播客python2018_Python视频教程下载-2018传智播客Python视频教程下载-西西软件下载...
  9. 权限系统设计学习总结(3)——多账户的统一登录
  10. python文本字符串比对_[Python] 利用HTML页面查看字符串差异
  11. 组态王、力控、MCGS、瑞尔、杰控等国内组态软件一点看法
  12. ib网卡无法启动,需要修改为以太网模式
  13. Android九宫格连线解锁-自定义View系列(9)
  14. 杭电数字电路课程设计——出租车计费器
  15. 监督学习、非监督学习、半监督学习(主动学习)
  16. bilibili有的视频没声音解决办法
  17. MFO问题与MFEA算法
  18. 苹果Mac电脑怎么卸载敬业签云便签软件?
  19. LORA大模型加速微调和训练算法
  20. 央行紧急通知:你在用的这种支付方式将有重大变化

热门文章

  1. Qmake建立常见的项目类型
  2. C++十进制数转换为二进制表示的算法(附完整源码)
  3. C语言实现adaline模型(附完整源码)
  4. C语言内存编址和寻址、内存对齐
  5. 将视频分成一帧一帧python_python ffmpeg任意提取视频帧的方法
  6. 4种方法让SpringMVC接收多个对象(转:http://blog.csdn.net/lutinghuan/article/details/46820023)
  7. Linux crontab的使用方式,sh脚本的编写,sh脚本自动启动tomcat服务器,sh监控系统运行情况
  8. s:if的用法(判断用户是否登录过了的操作)
  9. composer搭建php框架,用 Composer构建自己的 PHP 框架之基础准备
  10. python树莓派系统_树莓派系统 Raspbian Buster 发布