SpringBoot 定时任务

SpringBoot 定时任务

1.如何定时任务

1.1 开启定时任务

@EnableScheduling  //开启定时任务
@SpringBootApplication
public class  ManagerApplication {

    private static Logger logger = LoggerFactory.getLogger(ManagerApplication.class);


    public static void main(String[] args) {
        SpringApplication.run(ManagerApplication.class, args);
        logger.info("------------------------------------------------------------------");
        logger.info("application start success...");
        logger.info("--" +
                "----------------------------------------------------------------");
        try {
            System.in.read();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }


}


1.2 @Scheduled(预定的)选择要定时执行的任务

@Component
public class ScheduledService {

    
   @Scheduled(fixedRate = 1000*60*60)
    public void scheduled1() {
    }
}

== 定时在前一个任务阻塞时 会等待他,这个时候可以通过@Async 用异步来解决 ==

2.@Scheduled 参数详解

2.1 cron

2.1.1 cron表达式语法
[] [] [小时] [] [] [] []
序号说明是否必填通配符
1Y0-59, - * /
2Y0-59, - * /
3小时Y0-24, - * /
4Y1-31, - * /
5Y1-12/JAN-DEC(英文的1-12月), - * / L W
6星期Y1-7/SUN-SAT, - * / ? L #
7N1970-2099, - * /

通配符说明
, :表示指定多个值, 例如:在分的字段上设置 1,2,3,则1,2,3 分钟都会运行。
*:表示所有值。 例如:在分的字段上设置 *,表示每一分钟都会触发。
? :表示不指定值。只能在日和星期(周)中指定使用
-表示区间。例如:在分钟上设置1-10表示 1到10分钟都会 运行。
/ 用于递增触发。例如:在分上面设置”1/1” 表示从1分钟开始,每增1分钟触发一次(1,2,3,4…)
L: 表示最后(last)的意思(只支持月和星期)。在日字段设置上,表示当月的最后一天, 在星期字段上表示星期六,相当于”7”或”SAT”(百度指出星期六为一个星期的最后一天)。如果在”L”前加上数字,则表示该数据的最后一个。例如在周字段上设置”6L”这样的格式,则表示“本月最后一个星期五”,
W 表示离指定日期的最近那个工作日(周一至周五). 例如在日字段上置”15W”,表示离每月15号最近的那个工作日触发。如果15号正好是周六,则找最近的周五(14号)触发, 如果15号是周未,则找最近的下周一(16号)触发.如果15号正好在工作日(周一至周五),则就在该天触发。如果指定格式为 “1W”,它则表示每月1号往后最近的工作日触发。如果1号正是周六,则将在3号下周一触发。(注,”W”前只能设置具体的数字,不允许区间”-“)。
在这里插入图片描述
#:序号(表示每月的第几个周几),例如在周字段上设置”6#3”表示在每月的第三个周六.注意如果指定”#5”,正好第五周没有周六,则不会触发该配置(用在母亲节和父亲节再合适不过了) ;小提示:’L’和 ‘W’可以一组合使用。如果在日字段上设置”LW”,则表示在本月的最后一个工作日触发;周字段的设置,若使用英文字母是不区分大小写的,即MON与mon相同。
== 日和星期 只能存在一个 另一个用 ? ==

2.2 zone(地区)

cron表达式会基于该时区解析

2.3 fixedDelay

上一次执行后多少毫秒后执行注意是上一次执行完毕后

@Scheduled(fixedDelay = 2000)
开始,现在时间是 : 11:37:48scheduling-1
2019-12-12 11:37:48.884  INFO 18064 --- [           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat started on port(s): 8086 (http) with context path ''
2019-12-12 11:37:48.891  INFO 18064 --- [           main] com.wlgj.manager.ManagerApplication      : Started ManagerApplication in 7.266 seconds (JVM running for 10.023)
2019-12-12 11:37:48.894  INFO 18064 --- [           main] com.wlgj.manager.ManagerApplication      : ------------------------------------------------------------------
2019-12-12 11:37:48.895  INFO 18064 --- [           main] com.wlgj.manager.ManagerApplication      : application start success...
2019-12-12 11:37:48.895  INFO 18064 --- [           main] com.wlgj.manager.ManagerApplication      : ------------------------------------------------------------------
结束,现在时间是 : 11:37:51scheduling-1
开始,现在时间是 : 11:37:53scheduling-1
结束,现在时间是 : 11:37:56scheduling-1
开始,现在时间是 : 11:37:58scheduling-1
结束,现在时间是 : 11:38:01scheduling-1

2.4 fixedRate

上一次执行开始多少毫秒后执行注意是上一次执行开始后

  @Scheduled(fixedRate=2000)
    @Async
    public void test()
    {   System.out.println("开始,现在时间是 : "+format.format(new Date())+""+Thread.currentThread().getName());
        try {
            Thread.sleep(3000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        System.out.println("结束,现在时间是 : "+format.format(new Date())+""+Thread.currentThread().getName());
    }
开始,现在时间是 : 11:43:26ThreadPoolTaskExecutor-1
2019-12-12 11:43:26.379  INFO 17976 --- [           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat started on port(s): 8086 (http) with context path ''
2019-12-12 11:43:26.385  INFO 17976 --- [           main] com.wlgj.manager.ManagerApplication      : Started ManagerApplication in 7.273 seconds (JVM running for 9.84)
2019-12-12 11:43:26.389  INFO 17976 --- [           main] com.wlgj.manager.ManagerApplication      : ------------------------------------------------------------------
2019-12-12 11:43:26.390  INFO 17976 --- [           main] com.wlgj.manager.ManagerApplication      : application start success...
2019-12-12 11:43:26.390  INFO 17976 --- [           main] com.wlgj.manager.ManagerApplication      : ------------------------------------------------------------------
开始,现在时间是 : 11:43:28ThreadPoolTaskExecutor-2
结束,现在时间是 : 11:43:29ThreadPoolTaskExecutor-1
开始,现在时间是 : 11:43:30ThreadPoolTaskExecutor-3
结束,现在时间是 : 11:43:31ThreadPoolTaskExecutor-2
开始,现在时间是 : 11:43:32ThreadPoolTaskExecutor-1
结束,现在时间是 : 11:43:33ThreadPoolTaskExecutor-3
开始,现在时间是 : 11:43:34ThreadPoolTaskExecutor-2
  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值