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()));
}
}
- 运行
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
- 每一个域可出现的字符如下:
- 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年
- Seconds: 可出现
- 每一个域都使用数字,但还可以出现如下特殊字符,它们的含义是:
*
:表示匹配该域的任意值,假如在Minutes
域使用*
, 即表示每分钟都会触发事件。?
:只能用在DayofMonth
和DayofWeek
两个域。它也匹配域的任意值,但实际不会。因为DayofMonth和 DayofWeek会相互影响。例如想在每月的20日触发调度,不管20日到底是星期几,则只能使用如下写法: 13 13 15 20 ?, 其中最后一位只能用?
,而不能使用,
,如果使用*
表示不管星期几都会触发,实际上并不是这样。-
:表示范围,例如在 Minutes 域使用 5-20,表示从5分到20分钟每分钟触发一次。/
:表示起始时间开始触发,然后每隔固定时间触发一次,例如在 Minutes 域使用5/20,则意味着5分钟触发一次,而25,45等分别触发一次。,
:表示列出枚举值值。例如:在 Minutes 域使用5,20,则意味着在5和20分每分钟触发一次。L
:表示最后,只能出现在 DayofWeek 和 DayofMonth 域,如果在 DayofWeek 域使用 5L,意味着在最后的一个星期四触发。W
:表示有效工作日(周一到周五),只能出现在 DayofMonth 域,系统将在离指定日期的最近的有效工作日触发事件。例如:在 DayofMonth 使用 5W,如果5日是星期六,则将在最近的工作日:星期五,即4日触发。如果5日是星期天,则在6日(周一)触发;如果5日在星期一 到星期五中的一天,则就在5日触发。另外一点,W的最近寻找不会跨过月份。LW
:这两个字符可以连用,表示在某个月最后一个工作日,即最后一个星期五。#
:用于确定每个月第几个星期几,只能出现在 DayofMonth 域。例如在4#2,表示某月的第二个星期三。
更多内容请访问:IT源点
注意:本文归作者所有,未经作者允许,不得转载