springboot中基于注解@Scheduled的定时任务

基于注解@Scheduled默认为单线程,开启多个任务时,任务的执行时机会受上一个任务执行时间的影响。

创建定时器

//1.主要用于标记配置类,兼备Component的效果。
@Configuration 
 // 2.开启定时任务     
@EnableScheduling  
//3.添加定时任务
@Scheduled(cron = "0/5 * * * * ?")
//或直接指定时间间隔,例如:5秒
//@Scheduled(fixedRate=5000)

在定时任务中的Cron表达式参数分别表示:

  • 秒(0~59) 例如0/5表示每5秒
  • 分(0~59)
  • 时(0~23)
  • 日(0~31)的某天,需计算
  • 月(0~11)
  • 周几( 可填1-7 或 SUN/MON/TUE/WED/THU/FRI/SAT)

@Scheduled:除了支持灵活的参数表达式cron之外,还支持简单的延时操作,例如 fixedDelay ,fixedRate 填写相应的毫秒数即可。如示例中fixedRate=5000也是表示每隔5秒执行一次。

 

测试的时候只需要正常启动springboot项目,

注解了configuration在springboot启动的同时会自动加载了这个配置

测试的例子是每隔5秒钟自动执行一次

 

 

<think>好的,我现在需要解释一下Spring Boot中的@Scheduled注解。用户之前遇到了Redis连接的问题,现在可能是在学习或开发中遇到了定时任务的需求。用户可能对Spring Boot的基础有一定了解,但需要详细指导如何使用@Scheduled。 首先,我应该介绍@Scheduled的基本用途,即用于创建定时任务。然后需要提到如何启用它,比如通过@EnableScheduling注解。接下来要说明常见的几种配置方式,比如fixedRate、fixedDelay、cron表达式,这些是核心部分。 然后,用户可能需要知道参数的具体含义和使用例子,比如fixedRate和fixedDelay的区别,cron表达式的格式。这里要注意举一些例子,特别是常用的cron表达式,比如每分钟执行,每天几点执行等。 还需要提醒用户注意的任务执行的条件,比如单线程的问题,默认是单线程执行,所以长时间的任务可能会阻塞其他任务,这时候可能需要配置线程池。此外,提到异步执行@Async也是一个扩展点。 可能用户会遇到的问题,比如任务没有执行,这时候需要检查是否添加了@EnableScheduling,或者配置是否正确。还有关于应用运行环境,比如在测试时确保主类正确启动,定时任务所在的Bean被正确加载。 另外,结合用户之前的Redis问题,可以适当提一下如果定时任务中需要用到Redis或其他服务,要确保这些服务的可用性,避免因为依赖服务不可用导致定时任务失败,但可能当前问题主要是介绍@Scheduled,所以这部分可以简单带过。 最后,总结一下使用步骤,给出一个完整的例子,帮助用户快速上手。同时提醒一些常见错误和最佳实践,比如线程池配置、避免长时间任务等。</think>在 Spring Boot 中,`@Scheduled` 注解用于快速实现定时任务,允许你以简单的方式配置方法在特定时间或间隔重复执行。以下是核心知识点和用法: --- ### **1. 启用定时任务** 在 Spring Boot 主类或配置类上添加 `@EnableScheduling`,开启定时任务支持: ```java @SpringBootApplication @EnableScheduling // 关键注解 public class MyApplication { public static void main(String[] args) { SpringApplication.run(MyApplication.class, args); } } ``` --- ### **2. 定义定时任务方法** 在 Bean 的方法上使用 `@Scheduled` 注解,并指定执行规则: ```java @Component public class MyTask { // 每隔 5 秒执行一次(上一次开始时间点后 5 秒) @Scheduled(fixedRate = 5000) public void task1() { System.out.println("Fixed Rate Task: " + new Date()); } // 上一次任务结束后,间隔 3 秒再执行 @Scheduled(fixedDelay = 3000) public void task2() { System.out.println("Fixed Delay Task: " + new Date()); } // 使用 Cron 表达式(每分钟的第 30 秒执行) @Scheduled(cron = "30 * * * * ?") public void task3() { System.out.println("Cron Task: " + new Date()); } } ``` --- ### **3. 参数详解** #### **fixedRate** - **作用**:按固定频率执行,单位毫秒。 - **特点**:无论上一次任务是否完成,时间到就会执行。 - **示例**:`@Scheduled(fixedRate = 5000)` #### **fixedDelay** - **作用**:上一次任务执行完成后,间隔指定时间再执行,单位毫秒。 - **特点**:确保任务间隔包含任务执行时间。 - **示例**:`@Scheduled(fixedDelay = 3000)` #### **initialDelay** - **作用**:首次任务延迟执行时间,需与 `fixedRate` 或 `fixedDelay` 配合使用。 - **示例**:`@Scheduled(initialDelay = 1000, fixedRate = 5000)` #### **cron** - **作用**:通过 Cron 表达式定义复杂调度规则。 - **格式**:`秒 分 时 日 月 周 [年]`(年可选)。 - **示例**: - `0 0 12 * * ?`:每天中午 12 点触发。 - `0 */5 * * * ?`:每 5 分钟触发一次。 - `0 15 10 ? * MON-FRI`:每周一到周五的 10:15 触发。 --- ### **4. Cron 表达式语法** | 字段 | 允许值 | 特殊字符 | |------|----------------|----------------------| | 秒 | 0-59 | `, - * /` | | 分 | 0-59 | `, - * /` | | 时 | 0-23 | `, - * /` | | 日 | 1-31 | `, - * ? / L W C` | | 月 | 1-12 或 JAN-DEC | `, - * /` | | 周 | 1-7 或 SUN-SAT | `, - * ? / L # C` | | 年 | 可选(1970-2099)| `, - * /` | --- ### **5. 注意事项** #### **线程模型** - **默认单线程**:所有定时任务默认在同一个线程池中串行执行。如果某个任务耗时较长,会阻塞其他任务。 - **解决方案**:配置自定义线程池: ```java @Configuration public class SchedulerConfig implements SchedulingConfigurer { @Override public void configureTasks(ScheduledTaskRegistrar taskRegistrar) { taskRegistrar.setScheduler(Executors.newScheduledThreadPool(5)); } } ``` #### **避免长时间任务** 若任务执行时间超过间隔时间,需结合 `@Async` 实现异步执行: ```java @Scheduled(fixedRate = 5000) @Async // 需要配合 @EnableAsync 使用 public void asyncTask() { // 长时间任务 } ``` #### **动态修改定时规则** 通过 `ScheduledTaskRegistrar` 或数据库配置,可实现动态调整 Cron 表达式。 --- ### **6. 常见问题** 1. **任务未执行** - 检查是否添加了 `@EnableScheduling`。 - 确保任务方法所在的类已被 Spring 管理(如使用 `@Component`)。 2. **Cron 表达式错误** - 使用在线工具(如 [Cron Maker](https://www.cronmaker.com/))验证表达式。 3. **多实例重复执行** - 分布式环境下需结合分布式锁(如 Redis 锁)避免重复调度。 --- ### **总结** `@Scheduled` 是 Spring Boot 中实现定时任务的核心注解,通过简单配置即可满足大部分调度需求。结合线程池优化和异步处理,能有效提升任务执行的效率和可靠性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zhangvalue

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值