1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
@Component private Logger logger = Logger.getLogger( this .getClass()); /** * 定時(shí)任務(wù),1分鐘執(zhí)行1次,更新潛在客戶超時(shí)客戶共享狀態(tài) */ @Scheduled (cron= "0 0/1 8-20 * * ?" ) public void executeUpdateCuTask() { Thread current = Thread.currentThread(); logger.info( " 定時(shí)任務(wù)1:" +current.getId()+ ",name:" +current.getName()); } @Scheduled (cron= "0 0/1 8-20 * * ?" ) public void executeGetRepayTask() { Thread current = Thread.currentThread(); logger.info( " 定時(shí)任務(wù)2:" +current.getId()+ ",name:" +current.getName()); } } |
并行的定時(shí)任務(wù)需要添加配置文件
因?yàn)閟pring-boot的目的就是干掉配置文件,我在網(wǎng)上看到的很多都是通過配置文件來實(shí)現(xiàn)的,這里通過代碼配置實(shí)現(xiàn):
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
@Configuration public class ScheduleConfig implements SchedulingConfigurer{ @Override public void configureTasks(ScheduledTaskRegistrar taskRegistrar){ TaskScheduler taskScheduler = taskScheduler(); taskRegistrar.setTaskScheduler(taskScheduler); } @Bean (destroyMethod = "shutdown" ) public ThreadPoolTaskScheduler taskScheduler() { ThreadPoolTaskScheduler scheduler = new ThreadPoolTaskScheduler(); scheduler.setPoolSize( 20 ); scheduler.setThreadNamePrefix( "task-" ); scheduler.setAwaitTerminationSeconds( 60 ); scheduler.setWaitForTasksToCompleteOnShutdown( true ); return scheduler; } } |
網(wǎng)上教程說的需要在啟動(dòng)類上加上@EnableScheduling注解來發(fā)現(xiàn)注解@Scheduled的任務(wù)并后臺(tái)執(zhí)行。
可能我沒有通過啟動(dòng)類是通過外部tomcat啟動(dòng)的項(xiàng)目,所以沒有加這個(gè)注解也能實(shí)現(xiàn)定時(shí)任務(wù)
下面看下springboot 定時(shí)任務(wù)@Scheduled注解
需要定時(shí)器的地方好像還挺多. 之前項(xiàng)目中有用到使用定時(shí)器循環(huán)訂單時(shí)間,然后將超時(shí)的訂單狀態(tài)更改.
springboot的@Scheduled注解能夠很快速完成我們需要的定時(shí)任務(wù).
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
@Component public class ExampleTimer { SimpleDateFormat dateFormat = new SimpleDateFormat( "HH:mm:ss" ); /*每100秒執(zhí)行一次*/ @Scheduled(fixedRate = 100000) public void timerRate() { System.out.println("我是:timerRate"); } /*第一次10秒后執(zhí)行,當(dāng)執(zhí)行完后2秒再執(zhí)行*/ @Scheduled(initialDelay = 10000, fixedDelay = 2000) public void timerInit() { System.out.println("init : "+dateFormat.format(new Date())); } /*每天15:39:00時(shí)執(zhí)行*/ @Scheduled (cron = "0 39 15 * * ? " ) public void timerCron() { System.out.println( "current time : " + dateFormat.format( new Date())); } } |
其中需要注意的是:fixedRate和fixedDelay這兩個(gè)參數(shù)開始計(jì)時(shí)的時(shí)間不一樣.如果需要調(diào)用的方法執(zhí)行時(shí)間比較長, 這時(shí)差別就能體現(xiàn)出來.
fixedRate:上一次開始執(zhí)行時(shí)間點(diǎn)后再次執(zhí)行;
fixedDelay:上一次執(zhí)行完畢時(shí)間點(diǎn)后再次執(zhí)行;
還發(fā)現(xiàn)還有一種方法是調(diào)用配置文件的方法.
1
2
3
4
|
@Scheduled (fixedDelayString = "${jobs.fixedDelay}" ) public void getTask1() { System.out.println( "任務(wù)1,從配置文件加載任務(wù)信息,當(dāng)前時(shí)間:" + dateFormat.format( new Date())); } |
總結(jié)
以上所述是小編給大家介紹的spring-boot通過@Scheduled配置定時(shí)任務(wù)及定時(shí)任務(wù)@Scheduled注解的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對服務(wù)器之家網(wǎng)站的支持!
原文鏈接:http://www.cnblogs.com/yizw/archive/2017/11/17/7850310.html