`
tomrose
  • 浏览: 144529 次
  • 来自: ...
社区版块
存档分类
最新评论

job用法 JobDetailBean

阅读更多

代码片段

<!-- 要调度的任务-->
 <bean id="channelFileJob" class="org.springframework.scheduling.quartz.JobDetailBean">
  <property name="jobClass" value="com.job.FileJob" />
  <property name="applicationContextJobDataKey">
   <value>applicationContext</value>
  </property>
 </bean>
 <!-- 触发器-->
 <bean id="timerTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean">
  <property name="jobDetail">
   <ref bean="channelFileJob" />
  </property>
  <!-- 每天凌晨1点执行 "0 0 1 * * ?"-->
  <!-- 每分钟的0秒时执行一次 "0 * * * * ?"-->
  <!-- 每天凌晨1点钟执行一次 "0 0 1 * * ?"-->
  <property name="cronExpression">
  <value>0 0 1 * * ?</value>
  </property>
 </bean>
 <!--触发器调度控制器 -->
 <bean id="TimerTaskFactory" class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
  <property name="triggers">
   <list>
    <ref bean="timerTrigger" />
   </list>
  </property>
 </bean>

FileJob 要实现 Job接口 在job接口中定义具体job所要干的事情 而不用关心何时调用,怎么去调用。

job的调用策略在timerTrigger 中配置,配置完后要将 其注入到 TimerTaskFactory的list中去

 

以下是调度策略

网上似乎对Cron表达式的中文介绍相当少,我干脆就把Quartz中的doc翻译一下,各位需要的朋友可以快速了解一下大致用法:

一个Cron-表达式是一个由六至七个字段组成由空格分隔的字符串,其中6个字段是必须的而一个是可选的,如下:

 

字段名    允许的值    允许的特殊字符
   0-59    , - * /
   0-59    , - * /
小时    0-23    , - * /
   1-31    , - * ? / L W C
   1-12 or JAN-DEC    , - * /
周几    1-7 or SUN-SAT    , - * ? / L C #
年 (可选字段)    empty, 1970-2099    , - * /

 

'*' 字符可以用于所有字段,在“分”字段中设为"*"表示"每一分钟"的含义。

'?' 字符可以用在“日”和“周几”字段. 它用来指定 '不明确的值'. 这在你需要指定这两个字段中的某一个值而不是另外一个的时候会被用到。在后面的例子中可以看到其含义。

'-' 字符被用来指定一个值的范围,比如在“小时”字段中设为"10-12"表示"10点到12点".

',' 字符指定数个值。比如在“周几”字段中设为"MON,WED,FRI"表示"the days Monday, Wednesday, and Friday".

'/' 字符用来指定一个值的的增加幅度. 比如在“秒”字段中设置为"0/15"表示"第0, 15, 30, 和 45秒"。而 "5/15"则表示"第5, 20, 35, 和 50". 在'/'前加"*"字符相当于指定从0秒开始. 每个字段都有一系列可以开始或结束的数值。对于“秒”和“分”字段来说,其数值范围为0到59,对于“小时”字段来说其为0到23, 对于“日”字段来说为0到31, 而对于“月”字段来说为1到12。"/"字段仅仅只是帮助你在允许的数值范围内从开始"第n"的值。 因此对于“月”字段来说"7/6"只是表示7月被开启而不是“每六个月”, 请注意其中微妙的差别。

'L'字符可用在“日”和“周几”这两个字段。它是"last"的缩写, 但是在这两个字段中有不同的含义。例如,“日”字段中的"L"表示"一个月中的最后一天" —— 对于一月就是31号对于二月来说就是28号(非闰年)。而在“周几”字段中, 它简单的表示"7" or "SAT",但是如果在“周几”字段中使用时跟在某个数字之后, 它表示"该月最后一个星期×" —— 比如"6L"表示"该月最后一个周五"。当使用'L'选项时,指定确定的列表或者范围非常重要,否则你会被结果搞糊涂的。

'W' 可用于“日”字段。用来指定历给定日期最近的工作日(周一到周五) 。比如你将“日”字段设为"15W",意为: "离该月15号最近的工作日"。因此如果15号为周六,触发器会在14号即周五调用。如果15号为周日, 触发器会在16号也就是周一触发。如果15号为周二,那么当天就会触发。然而如果你将“日”字段设为"1W", 而一号又是周六, 触发器会于下周一也就是当月的3号触发,因为它不会越过当月的值的范围边界。'W'字符只能用于“日”字段的值为单独的一天而不是一系列值的时候。

'L'和'W'可以组合用于“日”字段表示为'LW',意为"该月最后一个工作日"。

'#' 字符可用于“周几”字段。该字符表示“该月第几个周×”,比如"6#3"表示该月第三个周五( 6表示周五而"#3"该月第三个)。再比如: "2#1" = 表示该月第一个周一而 "4#5" = 该月第五个周三。注意如果你指定"#5"该月没有第五个“周×”,该月是不会触发的。

'C' 字符可用于“日”和“周几”字段,它是"calendar"的缩写。它表示为基于相关的日历所计算出的值(如果有的话)。如果没有关联的日历, 那它等同于包含全部日历。“日”字段值为"5C"表示"日历中的第一天或者5号以后",“周几”字段值为"1C"则表示"日历中的第一天或者周日以后"。

对于“月份”字段和“周几”字段来说合法的字符都不是大小写敏感的。

下面是一些完整的例子:

 

表达式    含义
"0 0 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分每分钟一次触发
"0 0/5 14 * * ?"    每天从下午2点开始到2:55分结束每5分钟一次触发
"0 0/5 14,18 * * ?"    每天的下午2点至2:55和6点至6点55分两个时间段内每5分钟一次触发
"0 0-5 14 * * ?"    每天14:00至14:05每分钟一次触发
"0 10,44 14 ? 3 WED"    三月的每周三的14:10和14: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"    每月最后一个周五的10:15触发
"0 15 10 ? * 6L 2002-2005"    2002年至2005年的每月最后一个周五的10:15触发
"0 15 10 ? * 6#3"    每月的第三个周五的10:15触发

 

分享到:
评论

相关推荐

    DBMS_JOB使用方法

    详细介绍DBMS_JOB包的各函数操作,以及各函数对job的使用作用等。

    oracle中的job的用法

    主要介绍的是oracle中的job用法,oracle中定时执行存储过程

    Oracle JOB 用法小结

    Oracle JOB 用法小结 2007-6-20 11:51:36 Oracle JOB 用法小结  一、设置初始化参数 job_queue_processes  sql&gt; alter system set job_queue_processes=n;(n&gt;0)  job_queue_processes最大值为1000    ...

    oracle job 用法

    关于oracle job 的用法,里面包含例子

    Oracle Job的用法

    自己查阅资料后总结的一点Job的使用方法和技巧

    oracle job的用法

    oracle job的用法oracle job的用法oracle job的用法

    将 xxl-job-admin、xxl-job-core、xxl-job-executor 的源码引入项目中.docx

    xxl-job-admin 作为调度中心,有可视化的web管理界面,可将其作为一个模块以源码的方式引入到我们的项目中,我们可对其进行自定义的修改,但一般不需要;xxl-job-core 是 XXL-JOB的核心,绝大多数情况下我们不用对其...

    xxl-job-core-2.3.0-API文档-中文版.zip

    赠送jar包:xxl-job-core-2.3.0.jar ...使用方法:解压翻译后的API文档,用浏览器打开“index.html”文件,即可纵览文档内容。 人性化翻译,文档中的代码和结构保持不变,注释和说明精准翻译,请放心使用。

    xxl-job-core-2.3.0-API文档-中英对照版.zip

    使用方法:解压翻译后的API文档,用浏览器打开“index.html”文件,即可纵览文档内容。 人性化翻译,文档中的代码和结构保持不变,注释和说明精准翻译,请放心使用。 双语对照,边学技术、边学英语。

    job shop -matlab program

    job shop matlab program ,su

    python基于51job数据可视化图表展示源码.zip

    python基于51job数据可视化图表展示源码,基于51job工作招聘数据可视化图表展示 web 数据挖掘,ECharts可视化。python基于51job数据可视化图表展示源码,基于51job工作招聘数据可视化图表展示 web 数据挖掘,ECharts...

    xxl-job-admin-sqlserver.zip

    XXL-JOB是一个轻量级分布式任务...但该项目官方版的数据库使用的是mysql,里面的sql都是基于mysql写的,本人花了半天时间修改为SqlServer版的,目前测试可用没抛异常。 xxl-job-admin 版本为2.0.2 SqlServer版本为2012

    导出ORACLE - JOB

    从oracle库中导出自定义的job脚本。

    xxl-job本地jar包

    xxl-job,在页面管理定时任务,启动或者停止定时任务。本地程序启动时连接本地的xxl-job方便进行调试

    将xxl-job-1.7.2导入到myeclipse并部署到tomcat

    xxl-job-1.7.2导入到myeclipse并部署到tomcat的正确方法 基于tomcat8.x 亲测 完美通过

    分布式任务调度平台XXL-JOB(Oracle版)

    1/ 代码使用时首先打开下载好的压缩包解压,找到文件xxl-job-mysql-oracle-master\doc\db\tables_xxl_job_oralce.sql,并在PLSQL中生成; 2/ 之后在IDEA中打开项目,设置下maven环境,打开xxl-job-admin模块里面的...

    xxl-job oracle 适配版本

    基于最新 xxl-job 2.3.0 版本编写的 oracle 数据库适配版本

    quartz job持久化

    实现把job持久化数据库,里面有具体的说明文档 Quartz 1 1 通过quartz创建持久化定时执行任务 3 1.1 首先创建一个基本的web工程,所需jar包 3 1.2 Quartz配置文件quartz.properties 4 1.3 创建job 6 1.3.1 实现org....

    schedules和job使用大全

    本资源是描述oracle的定时任务执行的使用方法。 分别从9i的job和10g、11g的schedules两个不同的层次讲解。 讲解中有实例,欢迎下载使用。

    XXL-JOB分布式任务调度系统培训PPT

    XXL-JOB分布式任务调度系统培训PPT

Global site tag (gtag.js) - Google Analytics