您的位置:首页 > 编程语言 > Java开发

cronExpression 的写法,spring中执行定时任务,spring 集成Quartz

2017-08-22 17:08 411 查看
cronExpression主要的格式:{秒数} {分钟} {小时} {日期} {月份} {星期} {年份(可为空)}

注意:除了{日期}和{星期}可以使用”?”来实现互斥,表达无意义的信息之外,其他占位符都要具有具体的时间含义。

比如:3 3 3 ?* 1(每周1,3点3分3秒执行一次) 3 3 3 * * ?(每天的3点3分3秒执行一次)

秒数

允许值范围: 0~59 ,不允许为空值

“*” 代表每隔1秒钟触发;

“,” 代表在指定的秒数触发,比如”0,15,45”代表0秒、15秒和45秒时触发任务

“-” 代表在指定的范围内触发,比如”25-45”代表从25秒开始触发到45秒结束触发,每隔1秒触发1次

“/” 代表触发步进(step),”/”前面的值代表初始值(“*” 等同”0”),后面的值代表偏移量,比如”0/20”或者”*/20”代表从0秒钟开始,每隔20秒钟触发1次,即0秒触发1次,20秒触发1次,40秒触发1次;”5/20”代表5秒触发1次,25秒触发1次,45秒触发1次;”10-45/20”代表在[10,45]内步进20秒命中的时间点触发,即10秒触发1次,30秒触发1次

“15,30,45 * * * * ?” 每15秒,30秒,45秒时触发任务

“15-45 * * * * ?” 15到45秒内,每秒都触发任务

“15/5 * * * * ?” 每分钟的每15秒开始触发,每隔5秒触发一次

“15-30/5 * * * * ?” 每分钟的15秒到30秒之间开始触发,每隔5秒触发一次

分钟

允许值范围: 0~59 ,不允许为空值

“*” 代表每隔1分钟触发;

“,” 代表在指定的分钟触发,比如”10,20,40”代表10分钟、20分钟和40分钟时触发任务

“-” 代表在指定的范围内触发,比如”5-30”代表从5分钟开始触发到30分钟结束触 发,每隔1分钟触发

“/” 代表触发步进(step),”/”前面的值代表初始值(““等同”0”),后面的值代表偏移量,比如”0/25”或者”/25”代表从0分钟开始,每隔25分钟触发1次,即0分钟触发1次,第25分钟触发1次,第50分钟触发1次;”5/25”代表5分钟触发1次,30分钟触发1次,55分钟触发1次;”10-45/20”代表在[10,45]内步进20分钟命中的时间点触发,即10分钟触发1次,30分钟触发1次

小时

允许值范围: 0~23 ,不允许为空值,若值不合法,调度器将抛出SchedulerException异常

“*” 代表每隔1小时触发;

“,” 代表在指定的时间点触发,比如”10,20,23”代表10点钟、20点钟和23点触发任务

“-” 代表在指定的时间段内触发,比如”20-23”代表从20点开始触发到23点结束触发,每隔1小时触发

“/” 代表触发步进(step),”/”前面的值代表初始值(““等同”0”),后面的值代表偏移量,比如”0/1”或者”/1”代表从0点开始触发,每隔1小时触发1次;”1/2”代表从1点开始触发,以后每隔2小时触发一次;”19-20/2”表达式将只在19点触发

日期

允许值范围: 1~31 ,不允许为空值

“*” 代表每天触发;

“?” 与{星期}互斥,即意味着若明确指定{星期}触发,则表示{日期}无意义,以免引起 冲突和混乱

“,” 代表在指定的日期触发,比如”1,10,20”代表1号、10号和20号这3天触发

“-” 代表在指定的日期范围内触发,比如”10-15”代表从10号开始触发到15号结束触发,每隔1天触发

“/” 代表触发步进(step),”/”前面的值代表初始值(““等同”1”),后面的值代表偏移量,比如”1/5”或者”/5”代表从1号开始触发,每隔5天触发1次;”10/5”代表从10号开始触发,以后每隔5天触发一次;”1-10/2”表达式意味着在[1,10]范围内,每隔2天触发,即1号,3号,5号,7号,9号触发

“L” 如果{日期}占位符如果是”L”,即意味着当月的最后一天触发

“W “意味着在本月内离当天最近的工作日触发,所谓最近工作日,即当天到工作日的前后最短距离,如果当天即为工作日,则距离为0;所谓本月内的说法,就是不能跨月取到最近工作日,即使前/后月份的最后一天/第一天确实满足最近工作日;因此,”LW”则意味着本月的最后一个工作日触发,”W”强烈依赖{月份}>

“0 15 10 L * ?” 每个月最后一天的10点15分0秒触发任务

“0 15 10 LW * ?” 每个月最后一个工作日的10点15分0秒触发任务

月份

允许值范围: 1~12 (JAN-DEC),不允许为空值,若值不合法,调度器将抛出SchedulerException异常

“*” 代表每个月都触发;

“,” 代表在指定的月份触发,比如”1,6,12”代表1月份、6月份和12月份触发任务

“-” 代表在指定的月份范围内触发,比如”1-6”代表从1月份开始触发到6月份结束触发,每隔1个月触发

“/” 代表触发步进(step),”/”前面的值代表初始值(“*”等同”1”),后面的值代表偏移量,比如”1/2”或者”*/2”代表从1月份开始触发,每隔2个月触发1次;”6/6”代表从6月份开始触发,以后每隔6个月触发一次;”1-6/12”表达式意味着每年1月份触发

星期

允许值范围: 1~7 (SUN-SAT),1代表星期天(一星期的第一天),以此类推,7代表星期六(一星期的最后一天),不允许为空值

“*” 代表每星期都触发;

“?” 与{日期}互斥,即意味着若明确指定{日期}触发,则表示{星期}无意义,以免引起冲突和混乱

“,” 代表在指定的星期约定触发,比如”1,3,5”代表星期天、星期二和星期四触发

“-” 代表在指定的星期范围内触发,比如”2-4”代表从星期一开始触发到星期三结束触发,每隔1天触发

“/” 代表触发步进(step),”/”前面的值代表初始值(“*”等同”1”),后面的值代表偏移量,比如”1/3”或者”*/3”代表从星期天开始触发,每隔3天触发1次;”1-5/2”表达式意味着在[1,5]范围内,每隔2天触发,即星期天、星期二、星期四触发

“L” 如果{星期}占位符如果是”L”,即意味着星期的的最后一天触发,即星期六触发,L= 7或者 L = SAT,因此,”5L”意味着一个月的最后一个星期四触发

“#” 用来指定具体的周数,”#”前面代表星期,”#”后面代表本月第几周,比如”2#2”表示本月第二周的星期一,”5#3”表示本月第三周的星期四,因此,”5L”这种形式只不过是”#”的特殊形式而已

“0 15 10 ? * 5L” 每个月最后一个星期四的10点15分0秒触发任务

“0 15 10 ? * 5#3” 每个月第三周的星期四的10点15分0秒触发任务

年份

允许值范围: 1970~2099 ,允许为空

“*”代表每年都触发;

“,”代表在指定的年份才触发,比如”2011,2012,2013”代表2011年、2012年和2013年触发任务

“-“代表在指定的年份范围内触发,比如”2011-2020”代表从2011年开始触发到2020年结束触发,每隔1年触发

“/”代表触发步进(step),”/”前面的值代表初始值(“*”等同”1970”),后面的值代表偏移量,比如”2011/2”或者”*/2”代表从2011年开始触发,每隔2年触发1次

经典案例:

"30 * * * * ?" 每半分钟触发任务

"30 10 * * * ?" 每小时的10分30秒触发任务

"30 10 1 * * ?" 每天1点10分30秒触发任务

"30 10 1 20 * ?" 每月20号1点10分30秒触发任务

"30 10 1 20 10 ? *" 每年10月20号1点10分30秒触发任务

"30 10 1 20 10 ? 2011" 2011年10月20号1点10分30秒触发任务

"30 10 1 ? 10 * 2011" 2011年10月每天1点10分30秒触发任务

"30 10 1 ? 10 SUN 2011" 2011年10月每周日1点10分30秒触发任务

"15,30,45 * * * * ?" 每15秒,30秒,45秒时触发任务

"15-45 * * * * ?" 15到45秒内,每秒都触发任务

"15/5 * * * * ?" 每分钟的每15秒开始触发,每隔5秒触发一次

"15-30/5 * * * * ?" 每分钟的15秒到30秒之间开始触发,每隔5秒触发一次

"0 0/3 * * * ?" 每小时的第0分0秒开始,每三分钟触发一次

"0 15 10 ? * MON-FRI" 星期一到星期五的10点15分0秒触发任务

"0 15 10 L * ?" 每个月最后一天的10点15分0秒触发任务

"0 15 10 LW * ?" 每个月最后一个工作日的10点15分0秒触发任务

"0 15 10 ? * 5L" 每个月最后一个星期四的10点15分0秒触发任务

"0 15 10 ? * 5#3" 每个月第三周的星期四的10点15分0秒触发任务


如何使用

定时任务的很多方式的实现

http://www.cnblogs.com/baiduligang/p/4246993.html/

集成spring 和quartz处理定时任务

http://blog.csdn.net/jy_he/article/details/52198952/

http://blog.csdn.net/lw_power/article/details/49715605/

实践

创建job

<bean id="jobtask" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
<!-- 调用的类(指定包含任务执行体的 Bean 实例) -->
<property name="targetObject" ref="quartzTaskTest"></property>
<!-- 调用类中的方法(将指定 Bean 实例的某个特定方法包装成任务的执行体) -->
<property name="targetMethod" value="doTask"></property>
<property name="concurrent" value="false"></property>
</bean>


这个下面没有继承任何的东西,主要是由于MethodInvokingJobDetailFactoryBean,将我们进行了改造,改造成了JobDetail的实现类,这样才可以无侵入的实现执行任务

package com.common.utils.task;

import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Component;

import java.util.Date;

/**
* descrption: 使用quartz实现定时任务
* authohr: wangji
* date: 2017-08-22 14:13
*/
@Component("quartzTaskTest")
@Slf4j
public class QuartzTaskTest {

private volatile Integer count = 0;

public  void doTask()throws InterruptedException{
Date date1 = new Date();
log.info("count :"+count+++"  time:"+date1.toString());
Thread.currentThread().sleep(10000);
Date date = new Date();
log.info("休息了10秒,"+date.toString());
}
}


创建触发器,触发器有两种,一种就是简单的多少秒执行一下,另外的一种就是比较的复杂啦,使用cronExpression来处理,可以做到很多你无法想象的时间。

第一个就是没2秒的间隔执行一下,这个和Jobdetail是否支持并发执行有关系(concurrent==false不支持),如果支持并发执行,不管你有没有执行完成,都要继续执行任务,没有执行完成,在调度器中在启动一个线程进行执行,如果你有这样的需求,执行完成了之后多少秒开始执行,这里就不要使用并发的执行啦。

<bean id="simpleTrigger1"
class="org.springframework.scheduling.quartz.SimpleTriggerFactoryBean">
<property name="jobDetail" ref="jobtask" />
<property name="repeatInterval" value="2000" /><!--毫秒-->
<property name="startDelay" value="1000" />
</bean>
<bean id="cronTrigger"
class="org.springframework.scheduling.quartz.CronTriggerFactoryBean">
<property name="jobDetail" ref="jobtask1" />
<property name="startDelay" value="1000" />
<property name="cronExpression" value="30 * * * * ?"></property>
</bean>


创建调度工厂(你可以设置线程的数量),调度工厂就是线程池来执行触发器包含的定时任务

<bean id="startQuartz"  class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
<property name="triggers">
<list>
<ref bean="simpleTrigger1" />
<ref bean="cronTrigger"/>
</list>
</property>
</bean>


github:https://github.com/WangJi92/mybatits-study/blob/master/mybatis-study/study-8-spring-Hibernate%20-Quartz/pom.xml/ 自己可以实践一下。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: