SpringBoot 定时任务

本贴最后更新于 2309 天前,其中的信息可能已经渤澥桑田

前言

我们在编写 Spring Boot 应用中经常会遇到这样的场景,比如:我需要定时地发送一些短信、邮件之类的操作,也可能会定时地检查和监控一些标志、参数等。(或者在张健博客定时刷一波评论(笑.jpg))

创建定时任务

在 Spring Boot 中编写定时任务是非常简单的事,下面通过实例介绍如何在 Spring Boot 中创建定时任务,实现每过 5 秒输出一下当前时间。

  • 在 Spring Boot 的主类中加入 @EnableScheduling 注解,启用定时任务的配置

    /**

    • 开启定时任务
      */
      @SpringBootApplication
      @EnableScheduling
      public class GeccoApplication {

    public static void main(String[] args) {
    SpringApplication.run(GeccoApplication.class, args);
    }
    }

  • 创建定时任务实现类

方法注解 @Scheduled

@Scheduled(fixedDelay = 10000)
public void schedule() {
  Stopwatch started = Stopwatch.createStarted();
  int id = 26;
  while (id > 0) {
  Futures.addCallback(guavaExecutor.submit(new Crawler(Integer.toString(id))), new FutureCallback<String>() {
  @Override
  public void onSuccess(String result) {
  System.out.println("任务结果:" + result);
  }

  @Override
  public void onFailure(Throwable t) {
  System.out.println("任务异常:" + t.getMessage());
  }
 }, executor);
  id--;
  }
  started.elapsed(TimeUnit.MILLISECONDS);
  LOGGER.info("执行时间:{}", dateFormat.format(new Date(System.currentTimeMillis())));
  String s = "CPU数:" + PROCESSORS + ", 当前线程:" + Thread.currentThread().getName() + ", 线程池中线程数目:" + executor.getPoolSize() + ",队列中等待执行的任务数目:" +
  executor.getQueue().size() + ",已执行玩别的任务数目:" + executor.getCompletedTaskCount();
  LOGGER.info(s);
} 

测试

是不是很棒,很简单丫

第一次加载延迟指定时间后执行

第一次延迟 30 执行,之后按 fixedRate 的规则每 10 秒执行一次

@Scheduled(initialDelay = 30000,fixedDelay = 10000)

@Scheduled 详解

在上面的入门例子中,使用了 @Scheduled(fixedRate = 5000) 注解来定义每过 5 秒执行的任务,对于 @Scheduled 的使用可以总结如下几种方式:

  • @Scheduled(fixedRate = 5000) :上一次开始执行时间点之后 5 秒再执行
  • @Scheduled(fixedDelay = 5000) :上一次执行完毕时间点之后 5 秒再执行
  • @Scheduled(initialDelay=1000, fixedRate=5000) :第一次延迟 1 秒后执行,之后按 fixedRate 的规则每 5 秒执行一次
  • @Scheduled(cron="*/5 * * * * *") :通过 cron 表达式定义规则

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...