摘要:本文主要讲解使用SpringBoot创建定时任务。
项目中经常会需要做一些定时处理的任务,比如每间隔多久做个统计,发个邮件,清理个数据。这时候就要用到定时任务,SpringBoot中,创建定时任务非常简单,具体步骤如下:
在程序的启动类上加上@EnableScheduling注解,就会自动启用定时任务。
package com.java4all;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.scheduling.annotation.EnableScheduling;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
import java.time.LocalDateTime;
@SpringBootApplication
@EnableAutoConfiguration
@RestController
@EnableScheduling
@MapperScan("com.java4all.dao")
public class TmallApplication {
public static void main(String[] args) {
SpringApplication.run(TmallApplication.class, args);
}
@RequestMapping(value = "login",method = RequestMethod.GET)
public String login(){
return "欢迎登陆:"+ LocalDateTime.now();
}
}
单独创建一个类,用来存放定时任务,然后在每个定时任务方法上,用注解标明定时任务的执行周期。我这里以每间隔10秒打印一下当前系统时间为例,注意@Component注解。
package com.java4all.task;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
/**
* Author: momo
* Date: 2018/4/9
* Description:定时任务类
*/
@Component
public class ScheduledTask {
private final Logger logger = LoggerFactory.getLogger(getClass());
@Scheduled(fixedRate = 10000)
public void printTime(){
logger.info("定时任务,现在时间:"+System.currentTimeMillis());
}
}
注意,这里的时间,单位是毫秒,1秒=1000毫秒
项目启动后,我们就会在控制台看到每隔10秒会打印当前时间。