Springboot非分布式定時任務實現代碼
1. 核心注解
在springboot項目中我們可以很方便地使用spring自己的注解@Scheduled和@EnableScheduling配合來實現便捷開發定時任務。
@EnableScheduling注解的作用是發現注解@Scheduled的任務并后臺執行,此注解可以加到啟動類上也可以加到執行調度任務類上。
經測試,當有多個包含定時任務的類時,@EnableScheduling注解加在其中一個類上就可以保證所有定時任務的成功實現。
注意:定時任務的類上還需要配合使用@Configuration或@Component注解,這兩個注解都可以。
2. 實例代碼:
2.1 @EnableScheduling加在啟動類上;
import com.my.common.util.DateUtil;import org.springframework.scheduling.annotation.Scheduled;import org.springframework.stereotype.Component;import java.util.Date;/** * @description: * @author: Karl * @date: 2020/10/10 */@Componentpublic class TestSchedule01 { @Scheduled(cron = '0 * * * * ? ') public void test() { System.out.println('我是定時任務01,我執行了' + DateUtil.formatDateByDateTime(new Date())); }}
import com.my.common.util.DateUtil;import org.springframework.scheduling.annotation.Scheduled;import org.springframework.stereotype.Component;import java.util.Date;/** * @description: * @author: Karl * @date: 2020/10/10 */@Configurationpublic class TestSchedule02 { @Scheduled(cron = '1 * * * * ? ') public void test() { System.out.println('我是定時任務02,我執行了' + DateUtil.formatDateByDateTime(new Date())); }}
import org.springframework.boot.SpringApplication;import org.springframework.boot.autoconfigure.SpringBootApplication;import org.springframework.scheduling.annotation.EnableScheduling;@EnableScheduling@SpringBootApplicationpublic class DemoApplication { public static void main(String[] args) { SpringApplication.run(DemoApplication.class, args); }}
2.1 @EnableScheduling加在任務類上;
import com.my.common.util.DateUtil;import org.springframework.scheduling.annotation.Scheduled;import org.springframework.stereotype.Component;import java.util.Date;/** * @description: * @author: Karl * @date: 2020/10/10 */@Component@EnableSchedulingpublic class TestSchedule01 { @Scheduled(cron = '0 * * * * ? ') public void test() { System.out.println('我是定時任務01,我執行了' + DateUtil.formatDateByDateTime(new Date())); }}
import com.my.common.util.DateUtil;import org.springframework.scheduling.annotation.Scheduled;import org.springframework.stereotype.Component;import java.util.Date;/** * @description: * @author: Karl * @date: 2020/10/10 */@Configurationpublic class TestSchedule02 { @Scheduled(cron = '1 * * * * ? ') public void test() { System.out.println('我是定時任務02,我執行了' + DateUtil.formatDateByDateTime(new Date())); }}
注意:只需要在其中一個任務類上加上@EnableScheduling注解,所有的定時任務就都可以正常運行。
3. @Scheduled的幾種用法
@Scheduled這個注解支持3種定時方式,即:cron、fixedRate和fixedDelay
cron:是以表達式的形式來表示時間,最常見;
fixedRate:表示Scheduled隔多長時間調用一次,不管任務是否執行完;
fixedDelay:表示該任務執行完后隔多長時間再調用;
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。
相關文章:
1. 詳解JSP 內置對象request常見用法2. ASP.NET MVC實現下拉框多選3. ASP.NET MVC增加一條記錄同時添加N條集合屬性所對應的個體4. .NET Framework各版本(.NET2.0 3.0 3.5 4.0)區別5. 解決request.getParameter取值后的if判斷為NULL的問題6. JSP中param動作的實例詳解7. ASP.NET MVC實現本地化和全球化8. .Net反向代理組件Yarp用法詳解9. JS中的常見數組遍歷案例詳解(forEach, map, filter, sort, reduce, every)10. .NET中的MassTransit分布式應用框架詳解
