Spring(五):TaskScheduled计划任务与Cron表达式

star2017 1年前 ⋅ 294 阅读

Spring提供计划任务实现的注解,使用非常简单。首先通过配置类注解(@EnableScheduling)开启对计划任务的支持,然后在方法上注解(@Scheduled)申明这是一个计划任务。

@EnableScheduling开启调度

@Configuration
@ComponentScan("com.spring.scheduled")
@EnableScheduling//开启对计划任务的支持
public class TaskSchedulerConfig {
}

@Scheduled声明计划任务

import java.text.SimpleDateFormat;
import java.util.Date;

import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Service;

@Service
public class ScheduledTaskService {

    private static final SimpleDateFormat dateFormat = new SimpleDateFormat("HH:mm:ss");

    /**
     * 定时任务方法
     */
//    @Scheduled(fixedRate=5000)
    @Scheduled(cron="0/5 * *  * * ? ")
    public void reportCurrentTime() {
        System.out.println("每隔五秒报一次时:" + dateFormat.format(new Date()));
    }
}
  1. 运行
import org.springframework.context.annotation.AnnotationConfigApplicationContext;

public class SchedulerMain {

    public static void main(String[] args) {
        AnnotationConfigApplicationContext context = 
                new AnnotationConfigApplicationContext(TaskSchedulerConfig.class);
    }
}

@Scheduled 8种属性

注解包含 8 种可用的属性:

  • cron:指定cron表达式
  • zone:默认使用服务器默认时区。可以设置为java.util.TimeZone中的zoneId
  • fixedDelay:从上一次任务完成到下一次任务开始的间隔,单位 毫秒
  • fixedDelayString:同上,时间值是 String 类型
  • fixedRate:从上一次任务开始到下一次任务开始的间隔(两次调用之间以毫秒为单位的固定周期),单位 毫秒
  • fixedRateString:同上,时间值是 String 类型
  • initialDelay:任务首次执行延迟的时间,单位毫秒
  • initialDelayString:同上,时间值是 String 类型

Cron表达式

Cron 表达式是一个字符串,字符串以5或6个空格隔开,分为6或7个域,每一个域代表一个含义,Cron有如下两种语法格式:

Seconds Minutes Hours DayofMonth Month DayofWeek Year
Seconds Minutes Hours DayofMonth Month DayofWeek

Spring Scheduled Cron

  1. 每一个域可出现的字符如下:
    • Seconds: 可出现, - * /四个字符,有效范围为 0-59 的整
    • Minutes: 可出现, - * /四个字符,有效范围为 0-59 的整数
    • Hours: 可出现, - * /四个字符,有效范围为 0-23 的整数
    • DayofMonth: 可出现, - * / ? L W C八个字符,有效范围为 0-31 的整数
    • Month: 可出现, - * /四个字符,有效范围为 1-12 的整数或 JAN-DEC
    • DayofWeek: 可出现, - * / ? L C #四个字符,有效范围为 1-7 的整数或 SUN-SAT 两个范围。1表示星期天,2表示星期一, 依次类推
    • Year: 可出现, - * /四个字符,有效范围为1970-2099年
  2. 每一个域都使用数字,但还可以出现如下特殊字符,它们的含义是:
    • *:表示匹配该域的任意值,假如在 Minutes 域使用 *, 即表示每分钟都会触发事件。
    • ?:只能用在 DayofMonthDayofWeek 两个域。它也匹配域的任意值,但实际不会。因为DayofMonthDayofWeek会相互影响。例如想在每月的20日触发调度,不管20日到底是星期几,则只能使用如下写法: 13 13 15 20 ?, 其中最后一位只能用,而不能使用,如果使用*表示不管星期几都会触发,实际上并不是这样。
    • -:表示范围,例如在 Minutes 域使用 5-20,表示从5分到20分钟每分钟触发一次。
    • /:表示起始时间开始触发,然后每隔固定时间触发一次,例如在 Minutes 域使用5/20,则意味着5分钟触发一次,而25,45等分别触发一次。
    • ,:表示列出枚举值值。例如:在 Minutes 域使用5,20,则意味着在520分每分钟触发一次。
    • L:表示最后,只能出现在 DayofWeekDayofMonth 域,如果在 DayofWeek 域使用 5L,意味着在最后的一个星期四触发。
    • W:表示有效工作日(周一到周五),只能出现在 DayofMonth 域,系统将在离指定日期的最近的有效工作日触发事件。例如:在 DayofMonth 使用 5W,如果5日是星期六,则将在最近的工作日:星期五,即4日触发。如果5日是星期天,则在6日(周一)触发;如果5日在星期一 到星期五中的一天,则就在5日触发。另外一点,W的最近寻找不会跨过月份。
    • LW:这两个字符可以连用,表示在某个月最后一个工作日,即最后一个星期五。
    • #:用于确定每个月第几个星期几,只能出现在 DayofMonth 域。例如在4#2,表示某月的第二个星期三。
更多内容请访问:IT源点

相关文章推荐

全部评论: 0

    我有话说: