• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

Spring Boot文档阅读笔记-Scheduling Tasks

武飞扬头像
IT1995
帮助1

这篇博文将说明,如何一步一步完成Spring的任务调度功能。

主要是使用@Scheduled注解,完成每5秒打印当前时间。

首先在Maven中增加awaitility依赖包

  1.  
    <dependency>
  2.  
    <groupId>org.awaitility</groupId>
  3.  
    <artifactId>awaitility</artifactId>
  4.  
    <version>3.1.2</version>
  5.  
    <scope>test</scope>
  6.  
    </dependency>

整体Maven如下:

  1.  
    <?xml version="1.0" encoding="UTF-8"?>
  2.  
    <project xmlns="http://maven.apache.org/POM/4.0.0"
  3.  
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4.  
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  5.  
    <modelVersion>4.0.0</modelVersion>
  6.  
     
  7.  
    <groupId>org.example</groupId>
  8.  
    <artifactId>SchedulingTasks</artifactId>
  9.  
    <version>1.0-SNAPSHOT</version>
  10.  
     
  11.  
    <dependencies>
  12.  
     
  13.  
    <dependency>
  14.  
    <groupId>org.springframework.boot</groupId>
  15.  
    <artifactId>spring-boot-starter-web</artifactId>
  16.  
    <version>2.1.10.RELEASE</version>
  17.  
    </dependency>
  18.  
     
  19.  
    <dependency>
  20.  
    <groupId>org.awaitility</groupId>
  21.  
    <artifactId>awaitility</artifactId>
  22.  
    <version>3.1.2</version>
  23.  
    <scope>test</scope>
  24.  
    </dependency>
  25.  
     
  26.  
    </dependencies>
  27.  
     
  28.  
    </project>

创建调度调度任务的类,ScheduleTasks.java

  1.  
    package cn.it1995.component;
  2.  
     
  3.  
    import org.slf4j.Logger;
  4.  
    import org.slf4j.LoggerFactory;
  5.  
    import org.springframework.scheduling.annotation.Scheduled;
  6.  
    import org.springframework.stereotype.Component;
  7.  
     
  8.  
    import java.text.SimpleDateFormat;
  9.  
    import java.util.Date;
  10.  
     
  11.  
    @Component
  12.  
    public class ScheduledTasks {
  13.  
     
  14.  
    private static final Logger log = LoggerFactory.getLogger(ScheduledTasks.class);
  15.  
     
  16.  
    private static final SimpleDateFormat dateFormat = new SimpleDateFormat("HH:mm:ss");
  17.  
     
  18.  
    @Scheduled(fixedDelay = 5000)
  19.  
    public void reportCurrentTime(){
  20.  
     
  21.  
    log.info("The time is now {}", dateFormat.format(new Date()));
  22.  
    }
  23.  
    }

@Scheduled注解说明了在合适调用,比如fixedDelay说明每多少毫秒调用一次。这里还有其他选项,比如使用corn,这里全称应该是crontab,也就是定时任务,如@Scheduled(cron="...")

  1.  
    package cn.it1995;
  2.  
     
  3.  
    import org.springframework.boot.SpringApplication;
  4.  
    import org.springframework.boot.autoconfigure.SpringBootApplication;
  5.  
    import org.springframework.scheduling.annotation.EnableScheduling;
  6.  
     
  7.  
    @SpringBootApplication
  8.  
    @EnableScheduling
  9.  
    public class Main {
  10.  
     
  11.  
    public static void main(String[] args){
  12.  
     
  13.  
    SpringApplication.run(Main.class, args);
  14.  
    }
  15.  
    }

最后在@SpringBootApplication注解的地方,也就是main方法的地方,加上@EnableScheduling注解,这个注解的作用是使得后台任务调用执行被创建。

代码如下:Main.java

  1.  
    package cn.it1995;
  2.  
     
  3.  
    import org.springframework.boot.SpringApplication;
  4.  
    import org.springframework.boot.autoconfigure.SpringBootApplication;
  5.  
    import org.springframework.scheduling.annotation.EnableScheduling;
  6.  
     
  7.  
    @SpringBootApplication
  8.  
    @EnableScheduling
  9.  
    public class Main {
  10.  
     
  11.  
    public static void main(String[] args){
  12.  
     
  13.  
    SpringApplication.run(Main.class, args);
  14.  
    }
  15.  
    }

运行截图如下:

学新通

代码打包如下:

Java/SchedulingTasks at master · fengfanchen/Java · GitHub

这篇好文章是转载于:学新通技术网

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 学新通技术网
  • 本文地址: /boutique/detail/tanhgaahfe
系列文章
更多 icon
同类精品
更多 icon
继续加载