定时任务cron,定时自动实现某段代码

定时任务表达式
组成:cron一般由6个空格和7个字符构成,七个字符按照顺序分别表示:秒 分 时 日 月 周 年;有时候“年”这个域也可以不写,甚至于在云函数的触发器中有这一位还会提示表达错误。
cron表达式规则
一个cron表达式有至少6位(也可能7位)数字组成(每个数字称作元素),用空格分隔的时间元素。

按顺序依次为

  1. 秒(取值范围: 0~59,不能超过59,若取值为60的话,也会提示表达式不合格)
  2. 分钟(0~59)
  3. 小时(0~23)
  4. 天(1~31)
  5. 月(0~11)
  6. 星期(1~7 1=SUN 或 SUN,MON,TUE,WED,THU,FRI,SAT)
  7. 年份(1970-2199 可不写)

格式: 秒 分 时 天 月 星期 年

》其中每个元素可以是 一个值(如6) 或,
一个连续区间(例:9-12) 或, #意思: 9点 ~ 12点
一个间隔时间(8-18/4)(/表示每隔4小时) 或,
一个列表(1,3,5) 或,
通配符 (*)。

表达式的通配符
利用通配符可以表达一些时间逻辑,cron常用的通配符有“, - * /”这四个,分别来说:

逗号",”可以用来逗号隔开的多个时间点的并集,比如在月的位置上输入1,2表示在1月和2月都要执行;

短横“-”用来表示一个时间段,一个连续触发的范围,比如在秒的位置上输入10-30表示在10到30秒间每秒执行一次;

星号“*”用来表示所有值,可以理解成所有的值都执行,也就是“每”的意思,比如在秒的位置上输入 * 就表示每秒都运行;

正斜杠“/”表示间隔执行任务,格式是 “开始时间/时间间隔 ”,比如在秒的位置输入5/20表示从第5秒开始,每20秒执行一次‘;

还有一个通配符问号“?”也很重要,它只用于周和日的域,避免周和日的冲突,用于周和日之间进行互斥。通常在周和日设置的一个值,另外一个用?表示不指定值。比如要在每月的1号触发一个动作,但忽略周几,我们可以这么设置成 0 0 0 1 * ?

在这里插入图片描述

例子如下:
秒  分  时  天  月  星期  年
*/5 * * * * ? 每隔 5 秒执行一次

0 */1 * * * ? 每隔 1 分钟执行一次

0 0 2 1 * ? * 每月 1 日的凌晨 2 点执行一次

0 15 10 ? * MON-FRI 周一到周五每天上午 1015 执行作业

0 15 10 ? 6L 2002-2006 2002 年至 2006 年的每个月的最后一个星期五上午 10:15 执行作业

0 0 23 * * ? 每天 23 点执行一次

0 0 1 * * ? 每天凌晨 1 点执行一次

0 0 1 1 * ? 每月 1 日凌晨 1 点执行一次

0 0 23 L * ? 每月最后一天 23 点执行一次

0 0 1 ? * L 每周星期天凌晨 1 点执行一次

0 26,29,33 * * * ?26 分、29 分、33 分执行一次

0 0 0,13,18,21 * * ? 每天的 0 点、13 点、18 点、21 点都执行一次

0 0 10,14,16 * * ? 每天上午 10 点,下午 2 点,4 点执行一次

0 0/30 9-17 * * ? 朝九晚五工作时间内每半小时执行一次

0 0 12 ? * WED 每个星期三中午 12 点执行一次

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:102: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 触发
* * * * * ? *       解释: 每秒执行一次(所有元素都可以是任意值,那就从秒元素开始,以每秒为单位触发);如果前几位用数值定死了,那就以本位元素为单位来进行触发
 
0 * * * * ?         解释: 每1分钟触发一次(秒元素定死了,那就从分钟元素开始,*可以为分钟元素取值范围内的任意值,那就以每分钟为单位触发)
0/40 * * * * ?     解释: 增量后的值遇到当前元素取值范围最大值时,会被置为取值范围最小值   例: 0:00:000:00:400:01:000:01:400:02:00......
 
0 0 * * * ?         解释: 每1小时触发一次(秒元素和分钟元素都定死了,那就从小时元素开始,以每小时为单位触发)
0 0 0 * * ?         解释: 每天凌晨00000运行一次(秒、分、时元素都定死了,那就从日期元素开始,以每天为单位触发)
0 0 0 1 * ?         解释: 每月1号凌晨触发
 
0 0 10,14,16 * * ?  解释:小时元素用了一个列表,表示每天上午10点,下午2点,4点执行
 
0 0/30 9-17 * * ?   解释:分钟元素用了一个增量,小时元素用了一个连续区间,表示早9点到下午5点每半小时执行一次(9:009:301000......)
 
0 0 12 ? * WED      解释:小时元素用了一个数值,星期元素用了一个数值,表示每个星期三中午12"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-59)例: 14:00:0014:01:0014:02:00 ...... 14:59:00
 
"0 0/5 14 * * ?"    解释: 在每天下午2点到下午2:55(因为分钟元素只能取值到59,所以不会到3:00,只能到2:55)期间的每5分钟触发 例:14:00:0014:05:0014:10:00......14:55:00
 
"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:102:44触发 
 
"0 15 10 ? * MON-FRI" 解释:每月的每周的周一至周五每天的上午10:15触发 
 
"0 15 10 15 * ?"      解释: 每月15日上午10:15触发 (日和星期用一个数值和?指定,避免两者的日期冲突)
 
"0 15 10 L * ?"       解释: 每月最后一天的上午10:15触发 (L 用在了日期的位置上)
 
"0 15 10 ? * 6L"      解释: 每月的最后一个星期五上午10:15触发 (L用在星期元素上,6表示星期五)
 
"0 15 10 ? * 6L 2002-2005"  解释:2002年至2005年的每月的最后一个星期五上午10:15触发 
 
"0 15 10 ? * 6#3"    解释: 每月的第三个星期五上午10:15触发

使用cron实现定时执行某一段代码

import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.PropertySource;
import org.springframework.scheduling.Trigger;
import org.springframework.scheduling.annotation.EnableScheduling;
import org.springframework.scheduling.annotation.SchedulingConfigurer;
import org.springframework.scheduling.config.ScheduledTaskRegistrar;
import org.springframework.scheduling.support.CronTrigger;
import org.springframework.stereotype.Component;
@EnableScheduling //开启定时任务
@Component
@PropertySource(value = "classpath:/task.properties", encoding = "UTF-8")
public class CompleteScheduleConfig implements SchedulingConfigurer {

    @Value("${task.cron}")  //0 0 12 ? * SAT      
	private String taskCron;//每周六12点执行一次
	
    /**
     * 执行定时任务.
     */
    @Override
    public void configureTasks(ScheduledTaskRegistrar taskRegistrar) {
    	
    	System.out.println("加载定时任务。。。。。。。。");
    	//Runnable task0= () -> System.out.println("定时任务");
    	Runnable task0= () -> {
    	  System.out.println("定时任务");  //这里实现需要定时执行得代码
		}};
    	//Runnable task1= () -> dbk.FilesBak();
        taskRegistrar.addTriggerTask(task0, setTrigger());
       // taskRegistrar.addTriggerTask(task1, setTrigger("1"));
    }
    private Trigger setTrigger() {
    	Trigger trigger= triggerContext -> {
        	String cron=taskCron;//设置定时时间
        	if(cron.equals("")) {
        		return null;
        	}
            CronTrigger cronTrigger=new CronTrigger(cron);
            
            return cronTrigger.nextExecutionTime(triggerContext);
        };
        return trigger;
    }
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值