使用spring的@Scheduled注解执行定时任务,启动项目不输出警告

在applicationContext.xml中添加:html

xmlns:task="http://www.springframework.org/schema/task"
xsi:schemaLocation="http://www.springframework.org/schema/task
http://www.springframework.org/schema/task/spring-task-4.0.xsd">


<task:annotation-driven executor="myExecutor" scheduler="myScheduler" />
<task:executor id="myExecutor" pool-size="5" />
<task:scheduler id="myScheduler" pool-size="10" />

 

java代码:java

@Component
public class CleanExpireTokenTask {

    private Logger logger = LoggerFactory.getLogger(LogTag.BUSINESS);
    
    @Scheduled(cron = "0 * * * * ?")
    public void startUpdateSaleThread(){
        try{
            System.out.println("check token expire");
        }catch(Exception e){
            logger.error("Make salesReport faild",e);
        }
    }
}

 

注意:spring

实现类上要加注解@Component安全

定时器的任务方法不能有返回值app

配置及启动报错问题参考自
 
2016-11-22日 安全关闭spring定时任务线程池
java代码
 
  

@Resource(name = "myScheduler")
private ThreadPoolTaskScheduler threadPoolTaskScheduler;dom

/**
* 等待正在执行的定时任务执行完毕,再也不执行新的定时任务,
*/
public void shutdown(){
  threadPoolTaskScheduler.shutdown();
  // 等待任务执行完毕
  while(threadPoolTaskScheduler.getActiveCount() > 0){
    try {
      Thread.sleep(2000);
    } catch (InterruptedException e) {
      e.printStackTrace();
    }
  }
}测试

 

注:1.根据测试,经过此方式建立的定时任务,好比每分钟0秒执行任务,若是上一分钟0秒执行的任务还没执行完,则此次任务就不会启动。
  2.在ThreadPoolTaskScheduler调用shutdown方法后,不会杀掉正在执行的任务,已启动的定时任务能够执行完,这时若是定时任务执行Thread.sleep方法,会抛 InterruptedException,须要注意。
参考自
相关文章
相关标签/搜索