Spring基于注解的定时器@Scheduled

1.配置
spring配置文件中:

xmlns:task="http://www.springframework.org/schema/task"  
xsi:schemaLocation="http://www.springframework.org/schema/task  
http://www.springframework.org/schema/task/spring-task-3.1.xsd"
<!--task任务扫描注解-->
<task:executor id="taskExecutor" pool-size="${task.pool_size}" 
 queue-capacity="${task.queue_capacity}" keep-alive="${task.keep_alive}" 
 rejection-policy="CALLER_RUNS" />
<task:annotation-driven executor="taskExecutor" />
<!--配置扫描位置-->
<context:component-scan base-package="com.xxxx" />

2.需要注意的几点:

  1. spring的@Scheduled注解 需要写在方法的实现
  2. 定时器的任务方法不能有返回值
    (如果有返回值,spring初始化的时候会告诉你有个错误、需要设定一个proxytargetclass的某个值为true、具体就去百度google吧)
  3. 实现类上要有组件的注解@Component

3.定时方式:

  1. 固定延迟时间@Scheduled(fixedDelay = 5000)
    这个周期是以上一个调用任务的完成时间为基准,在上一个任务完成之后,5s后再次执行

  2. 固定速率执行@Scheduled(fixedRate = 5000)
    这个周期是以上一个任务开始时间为基准,从上一任务开始执行后5s再次调用

  3. cron表达式@Scheduled(cron = “0 0 2 * * ?”) ——每天凌晨2点执行
    一个cron表达式有至少6个(也可能7个)有空格分隔的时间元素。
    按顺序依次为:

    字段允许值允许的特殊字符
    0-59, - * /
    0-59, - * /
    0-23, - * /
    日期1-31, - * ? / L W C
    月份1-12 或者 JAN-DEC, - * /
    星期1-7 或者 SUN-SAT, - * ? / L C #
    年(可选)留空, 1970-2099, - * /

    其中每个元素可以是

    元素含义例子
    一个值(如6)固定时间
    一个连续区间(9-12)xx到xx
    一个间隔时间(8-18/4)(/表示每隔4小时)每隔在子表达式(分钟)里的“0/15”表示从第0分钟开始,每15分钟;在子表达式(分钟)里的“3/20”表示从第3分钟开始,每20分钟(它和“3,23,43”)的含义一样
    一个列表(1,3,5)
    通配符全都/每一* 在子表达式(月)里表示每个月的含义,在子表达式(天(星期))表示星期的每一天
    日期/星期 ?这两个元素互斥必须要对其中一个设置"?"==
    日期/星期 L最后在天(月)子表达式中,“L”表示一个月的最后一天;在天(星期)自表达式中,“L”表示一个星期的最后一天,也就是SAT;如果在“L”前有具体的内容,它就具有其他的含义了,例如:“6L”放在日期表示这个月的倒数第6天,放在星期表示这个月的最后一个星期五,等同“FRIL”;注意:在使用“L”参数时,不要指定列表或范围,因为这会导致问题
    日期 W最近有效工作日使用5W,如果5日是星期六,则将在最近的工作日:星期五,即4日触发;5日是星期天,则在6日(周一)触发;如果5日在星期一到星期五中的一天,则就在5日触发;不跨月
    星期 # 数字用于确定每个月第几个星期几4#2,表示某月的第二个星期三

    0 0 10,14,16 * * ? 每天上午10点,下午2点,4点
    0 0/30 9-17 * * ? 朝九晚五工作时间内每半小时(每30分钟)
    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期间的(从0开始的)每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:10和2: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触发

https://luanxiyuan.iteye.com/blog/2297329
https://www.cnblogs.com/javahr/p/8318728.html

### 回答1: spring定时器@scheduled是一种基于注解的定时任务调度方式,可以在指定的时间间隔或固定时间点执行任务。通过在方法上添加注解@scheduled,可以指定任务的执行时间、执行频率、执行条件等。这种方式简单易用,适用于各种场景下的定时任务调度。 ### 回答2: Spring定时器@scheduled是一种非常常用和方便的定时任务调度方式,它是Spring框架中的一部分。使用@scheduled注解可以让方法按照一定的时间间隔或者某个特定时间点去执行,可以说是非常方便实用了。 @scheduled注解必须放在方法上,可以设置多个属性来指定任务的执行时间和间隔。其中,cron属性是一个非常重要的属性,它使用了系统的cron表达式来指定任务的执行时间,这样我们可以实现非常精细的任务调度,实现复杂的任务流程。 除了cron之外,还有fixedDelay和fixedRate属性,分别表示延迟多少毫秒后再次执行和间隔多少毫秒再次执行,这两个属性适用于固定间隔执行的任务。 @scheduled注解还支持设置initialDelay属性,表示任务延迟多少秒后开始执行。这在某些情况下非常有用,如需要在系统启动后延迟一定时间再执行的任务。 除了定时任务之外,@scheduled还支持retry注解,可以在任务执行失败时自动重新执行几次,这对于保证任务的可靠性非常重要。 需要注意的是,@scheduled注解只能用于Spring Bean中的方法,也就是说,这样的方法必须是由Spring容器来管理的,只有被纳入了Spring容器的Bean才能被@scheduled注解所标注。 总之,Spring定时器@scheduled的使用非常广泛,实用性非常高。需要我们根据业务需求来灵活运用,并注意任务的可靠性和性能问题。 ### 回答3: Spring框架提供了一个方便的定时任务处理的功能模块:@Scheduled。这个注解就是用来创建一个定时任务方法的。 基本使用方式 在一个方法上添加 @Scheduled 注解, 并设置触发执行时间。例如,下面代码是定义了一个每5秒执行一次的定时任务: @Scheduled(fixedRate = 5000) public void doSomething() { //TODO: 实现定时任务所需的业务逻辑... } 同时要注意,要开启对 @Scheduled 的支持,需要在 Spring 配置文件中添加以下配置: <task:annotation-driven/> 其他属性 除了 fixedRate 属性,还有另外两个常用属性: - fixedDelay:在两次执行之间存在延迟(即两次执行之间需要等等),单位是毫秒; - cron:使用 Cron 表达式支持,更加灵活,更精准地设置执行的时间,类似于Linux中的Crontab。比如: - @Scheduled(cron="0 15 10 ? * *") // 每天10点15分执行 - @Scheduled(cron="0 0/5 14,18 * * ?") // 每天下午2点到3点,每个五分钟执行一次 总结 @Scheduled 可以让程序员非常方便地实现定时任务的功能,使用起来也很容易理解。 同时因为 Spring 框架支持的任务类型非常丰富,包括定时任务、异步执行、并发运行、任务队列等等,可谓是应对各种需求场景的优秀工具。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值