【Spring全家桶】Spring Task 定时任务实战:从入门到 Cron 表达式精通
在开发中,我们经常需要处理一些定时任务:比如每天凌晨同步数据、每隔 1 小时清理缓存、或者在宠物领养成功 30 天后自动发送回访提醒。Spring Task 为我们提供了最简单的实现方案。
一、 核心概念
Spring Task 是 Spring Framework 的一部分,通过注解即可实现任务调度。
- TaskScheduler:任务调度器,负责执行定时任务。
- Trigger:触发器,决定任务什么时候执行(通常使用 Cron 表达式)。
二、 快速上手步骤
1. 开启定时任务支持
在 Spring Boot 启动类或配置类上添加 @EnableScheduling 注解。
java
@SpringBootApplication
@EnableScheduling // 开启定时任务开关
public class PetApplication {
public static void main(String[] args) {
SpringApplication.run(PetApplication.class, args);
}
}
2. 编写定时任务类
只需在普通 Service 类的方法上添加 @Scheduled 注解即可。
java
@Component
public class PetTask {
// 每隔 5 秒执行一次
@Scheduled(fixedRate = 5000)
public void checkAdoptionStatus() {
System.out.println("执行状态检查:" + LocalDateTime.now());
}
}
三、 @Scheduled 注解参数详解
Spring Task 提供了三种主流的触发方式:
| 参数 | 含义 | 示例 |
|---|---|---|
| fixedRate | 固定频率。从任务开始执行时计时,每隔 X 毫秒执行。 | @Scheduled(fixedRate = 5000) |
| fixedDelay | 固定延迟。从任务结束执行时计时,间隔 X 毫秒再执行。 | @Scheduled(fixedDelay = 5000) |
| cron | Cron 表达式。支持非常复杂的定时规则。 | @Scheduled(cron = "0 0 2 * * ?") |
四、 重点:Cron 表达式快速通关
Cron 表达式是一个字符串,分为 6 或 7 个域,空格隔开:
秒 分 时 日 月 周 [年]
0 0 2 1 * ?:每月 1 号凌晨 2 点执行。0 0/30 9-17 * * ?:朝九晚五工作时间内,每隔 30 分钟执行。0 0 12 ? * WED:每周三中午 12 点执行。
五、 进阶:配置多线程任务池
注意:Spring Task 默认是单线程的。如果你的项目中有多个任务同时到达执行时间,它们会排队等待。
为了提高性能,建议配置线程池:
java
@Configuration
public class SchedulingConfig implements SchedulingConfigurer {
@Override
public void configureTasks(ScheduledTaskRegistrar taskRegistrar) {
// 设置 10 个线程的池
taskRegistrar.setScheduler(Executors.newScheduledThreadPool(10));
}
}
六、 实战场景:宠物系统定时提醒
在你的项目中,可以这样应用:
java
@Service
public class ReminderTask {
@Autowired
private HealthRecordMapper healthMapper;
/**
* 每天早上 8 点,扫描即将需要接种疫苗的宠物并发送通知
*/
@Scheduled(cron = "0 0 8 * * ?")
public void vaccineReminder() {
// 查询明天需要打疫苗的记录
List<HealthRecord> list = healthMapper.findUpcomingVaccines();
for (HealthRecord record : list) {
// 发送逻辑...
System.out.println("提醒:宠物 " + record.getPetId() + " 明天需接种疫苗");
}
}
}
七、 总结
Spring Task 的优势在于零配置、上手快 。但如果你的项目是分布式集群部署,需要注意 Spring Task 会在多台服务器上同时运行,产生重复任务。此时建议配合 Redis 分布式锁 使用,或者升级为 XXL-JOB 等分布式任务平台。
作者: [CodeToGym]