前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Quartz学习笔记(三)配置文件实现任务调度

Quartz学习笔记(三)配置文件实现任务调度

作者头像
小柒2012
发布2018-04-13 16:41:03
5000
发布2018-04-13 16:41:03
举报
文章被收录于专栏:IT笔记IT笔记

在JavaEE系统中,我们会经常用到定时任务,比如每天凌晨生成前天报表,每一小时生成汇总数据等等。 我们可以使用java.util.Timer结合java.util.TimerTask来完成这项工作,但时调度控制非常不方便,并且我们需要大量的代码。 使用Quartz框架无疑是非常好的选择,并且与Spring可以非常方便的集成,下面介绍它们集成方法和Cron表达式的详细介绍。

  1. Spring 整合Quartz配置: <!-- 要调用的工作类 --> <bean id="quartzJob" class="web.Quartz"></bean> <!-- 定义调用对象和调用对象的方法 --> <bean id="jobtask" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean"> <!-- 调用的类 --> <property name="targetObject"> <ref bean="quartzJob"/> </property> <!-- 调用类中的方法 --> <property name="targetMethod"> <value>work</value> </property> </bean> <!-- 定义触发时间 --> <bean id="doTime" class="org.springframework.scheduling.quartz.CronTriggerBean"> <property name="jobDetail"> <ref bean="jobtask"/> </property> <!-- cron表达式 --> <property name="cronExpression"> <!-- 每隔10秒执行一次--> <value>0/10 * * * * ?</value> </property> </bean> <!-- 总管理类 如果将lazy-init='false'那么容器启动就会执行调度程序 --> <bean id="startQuertz" lazy-init="false" autowire="no" class="org.springframework.scheduling.quartz.SchedulerFactoryBean"> <property name="triggers"> <list> <ref bean="doTime"/> </list> </property> </bean>
  2. web.xml 配置:
代码语言:javascript
复制
<context-param>
   <param-name>contextConfigLocation</param-name>
   <param-value>
    /WEB-INF/classes/applicationContext*.xml
   </param-value>
</context-param>
<servlet>
   <servlet-name>context</servlet-name>
   <servlet-class>
    org.springframework.web.context.ContextLoaderServlet
   </servlet-class>
   <load-on-startup>1</load-on-startup>
</servlet>
  1. 测试代码
代码语言:javascript
复制
package web;
public class Quartz {
    public void work()
    {
          System.out.println("Quartz的任务调度!!!");
       }
}

附:cronExpression表达式解释: 0 0 12 ?---------------在每天中午12:00触发 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:00至2:59之间每分钟触发一次 0 0/5 14 ** ?---------------每天在下午2:00至2:59之间每5分钟触发一次 0 0/5 14,18 ?---------------每天在下午2:00至2:59和6:00至6:59之间的每5分钟触发一次 0 0-5 14 ** ?---------------每天在下午2:00至2:05之间每分钟触发一次 0 10,44 14? 3 WED---------------每三月份的星期三在下午2:00和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, 2003, 2004 and 2005年的每个月的最后一个星期五的上午10:15触发 0 15 10 ? *6#3---------------在每个月的第三个星期五的上午10:15触发 0 0 12 1/5 *?---------------从每月的第一天起每过5天的中午12:00时触发 0 11 11 1111 ?---------------在每个11月11日的上午11:11时触发.-

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2016-07-26,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档