1. 程式人生 > >@Scheduled(cron = "0 0 * * * ?")實現定時任務

@Scheduled(cron = "0 0 * * * ?")實現定時任務

//每一個小時執行一次

@Scheduled(cron = "0 0 * * * ?")
public void saveDailyScoreScheduled() {
try {
logger.info("loadDeviceEvents start>>>>" + new Date());
loadDeviceEvents(ZonedDateTime.now().toEpochSecond(),null);
logger.info("loadDeviceEvents end >>>>" + new Date());
} catch (Exception e) {
logger.error("loadDeviceEvents error >>>>" ,e.toString());

}
}

/**

每兩個小時執行一次
* Scheduled task
*/
@Scheduled(cron = "0 0 */2 * * ?")
public void loadMxpDeviceIssueStatusScheduled() {
try {
log.info("loadMxpDeviceIssueStatusScheduled start>>>>" + new Date());
loadMxpDeviceIssueStatus();
log.info("loadMxpDeviceIssueStatusScheduled end >>>>" + new Date());
} catch (Exception e) {
log.error("loadMxpDeviceIssueStatusScheduled error >>>>" ,e.toString());

}
}

具體知識:

http://blog.csdn.net/prisonbreak_/article/details/49180307

Spring配置檔案xmlns加入

xmlns:task="http://www.springframework.org/schema/task"

xsi:schemaLocation中加入

     http://www.springframework.org/schema/task
     http://www.springframework.org/schema/task/spring-task-3.0.xsd"
<context:component-scan base-package="com.imwoniu.*" />

任務掃描註解

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

程式碼實現:

註解@Scheduled 可以作為一個觸發源新增到一個方法中,例如,以下的方法將以一個固定延遲時間5秒鐘呼叫一次執行,這個週期是以上一個呼叫任務的完成時間為基準,在上一個任務完成之後,5s後再次執行:

@Scheduled(fixedDelay = 5000)
public void doSomething() { 
    // something that should execute periodically
}

如果需要以固定速率執行,只要將註解中指定的屬性名稱改成fixedRate即可,以下方法將以一個固定速率5s來呼叫一次執行,這個週期是以上一個任務開始時間為基準,從上一任務開始執行後5s再次呼叫:

@Scheduled(fixedRate = 5000)
public void doSomething() { 
    // something that should execute periodically
}

如果簡單的定期排程不能滿足,那麼cron表示式提供了可能

複製程式碼
package com.imwoniu.task;

import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;

@Component
public class TaskDemo {
    
    @Scheduled(cron = "0 0 2 * * ?")  //每天凌晨兩點執行
        void doSomethingWith(){
            logger.info("定時任務開始......");
            long begin = System.currentTimeMillis();
        
            //執行資料庫操作了哦...
        
            long end = System.currentTimeMillis();
            logger.info("定時任務結束,共耗時:[" + (end-begin) / 1000 + "]秒");
    }
}
複製程式碼

以下內容摘自http://biaoming.iteye.com/blog/39532

一個cron表示式有至少6個(也可能7個)有空格分隔的時間元素。

按順序依次為

秒(0~59)

分鐘(0~59)

小時(0~23)

天(月)(0~31,但是你需要考慮你月的天數)

月(0~11)

天(星期)(1~7 1=SUN 或 SUN,MON,TUE,WED,THU,FRI,SAT)

7.年份(1970-2099)

其中每個元素可以是一個值(如6),一個連續區間(9-12),一個間隔時間(8-18/4)(/表示每隔4小時),一個列表(1,3,5),萬用字元。由於"月份中的日期"和"星期中的日期"這兩個元素互斥的,必須要對其中一個設定?.

0 0 10,14,16 * * ? 每天上午10點,下午2點,4點
0 0/30 9-17 * * ?   朝九晚五工作時間內每半小時
0 0 12 ? * WED 表示每個星期三中午12點 
"0 0 12 * * ?" 每天中午12點觸發 
"0 15 10 ? * *" 每天上午10:15觸發 
"0 15 10 * * ?" 每天上午10:15觸發 
"0 15 10 * * ? *" 每天上午10:15觸發 
"0 15 10 * * ? 2005" 2005年的每天上午10:15觸發 
"0 * 14 * * ?" 在每天下午2點到下午2:59期間的每1分鐘觸發 
"0 0/5 14 * * ?" 在每天下午2點到下午2:55期間的每5分鐘觸發 
"0 0/5 14,18 * * ?" 在每天下午2點到2:55期間和下午6點到6:55期間的每5分鐘觸發 
"0 0-5 14 * * ?" 在每天下午2點到下午2:05期間的每1分鐘觸發 
"0 10,44 14 ? 3 WED" 每年三月的星期三的下午2:10和2:44觸發 
"0 15 10 ? * MON-FRI" 週一至週五的上午10:15觸發 
"0 15 10 15 * ?" 每月15日上午10:15觸發 
"0 15 10 L * ?" 每月最後一日的上午10:15觸發 
"0 15 10 ? * 6L" 每月的最後一個星期五上午10:15觸發 
"0 15 10 ? * 6L 2002-2005" 2002年至2005年的每月的最後一個星期五上午10:15觸發 
"0 15 10 ? * 6#3" 每月的第三個星期五上午10:15觸發 

有些子表示式能包含一些範圍或列表

例如:子表示式(天(星期))可以為 “MON-FRI”,“MON,WED,FRI”,“MON-WED,SAT”

“*”字元代表所有可能的值

因此,“*”在子表示式()裡表示每個月的含義,“*”在子表示式(天(星期))表示星期的每一天

“/”字元用來指定數值的增量

例如:在子表示式(分鐘)裡的“0/15”表示從第0分鐘開始,每15分鐘

         在子表示式(分鐘)裡的“3/20”表示從第3分鐘開始,每20分鐘(它和“3,23,43”)的含義一樣


“?”字元僅被用於天(月)和天(星期)兩個子表示式,表示不指定值

當2個子表示式其中之一被指定了值以後,為了避免衝突,需要將另一個子表示式的值設為“?”

“L” 字元僅被用於天(月)和天(星期)兩個子表示式,它是單詞“last”的縮寫

但是它在兩個子表示式裡的含義是不同的。

在天(月)子表示式中,“L”表示一個月的最後一天

在天(星期)自表示式中,“L”表示一個星期的最後一天,也就是SAT

如果在“L”前有具體的內容,它就具有其他的含義了

例如:“6L”表示這個月的倒數第6天,“FRIL”表示這個月的最一個星期五

注意:在使用“L”引數時,不要指定列表或範圍,因為這會導致問題

欄位   允許值   允許的特殊字元
0-59 , - * /
0-59 , - * /
小時 0-23 , - * /
日期 1-31 , - * ? / L W C
月份 1-12 或者 JAN-DEC , - * /
星期 1-7 或者 SUN-SAT , - * ? / L C #
年(可選) 留空, 1970-2099 , - * /