您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關SpringBoot2如何使用定時任務和異步任務的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
按照指定時間執行的程序。
數據分析 數據清理 系統服務監控
同步調用
程序按照代碼順序依次執行,每一行程序都必須等待上一行程序執行完成之后才能執行;
異步調用
順序執行時,不等待異步調用的代碼塊返回結果就執行后面的程序。
短信通知 郵件發送 批量數據入緩存
@Scheduled(fixedRate = 5000) :上一次開始執行時間點之后5秒再執行 @Scheduled(fixedDelay = 5000) :上一次執行完畢時間點之后5秒再執行 @Scheduled(initialDelay=1000, fixedRate=5000) :第一次延遲1秒后執行,之后按fixedRate的規則每5秒執行一次 @Scheduled(cron="/5") :通過cron表達式定義規則
import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; import java.text.SimpleDateFormat; import java.util.Date; /** * 時間定時任務 */ @Component public class TimeTask { Logger LOG = LoggerFactory.getLogger(TimeTask.class.getName()) ; private static final SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss") ; /** * 每3秒打印一次系統時間 */ @Scheduled(fixedDelay = 3000) public void systemDate (){ LOG.info("當前時間::::"+format.format(new Date())); } }
@EnableScheduling // 啟用定時任務 @SpringBootApplication public class TaskApplication { public static void main(String[] args) { SpringApplication.run(TaskApplication.class,args) ; } }
import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.scheduling.annotation.Async; import org.springframework.stereotype.Component; @Component public class AsyncTask { private static final Logger LOGGER = LoggerFactory.getLogger(AsyncTask.class) ; /* * [ asyncTask1-2] com.boot.task.config.AsyncTask : ======異步任務結束1====== * [ asyncTask1-1] com.boot.task.config.AsyncTask : ======異步任務結束0====== */ // 只配置了一個 asyncExecutor1 不指定也會默認使用 @Async public void asyncTask0 () { try{ Thread.sleep(5000); }catch (Exception e){ e.printStackTrace(); } LOGGER.info("======異步任務結束0======"); } @Async("asyncExecutor1") public void asyncTask1 () { try{ Thread.sleep(5000); }catch (Exception e){ e.printStackTrace(); } LOGGER.info("======異步任務結束1======"); } }
這里可以不指定,指定執行的線城池,可以更加方便的監控和管理異步任務的執行。
import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor; import java.util.concurrent.Executor; import java.util.concurrent.ThreadPoolExecutor; /** * 定義異步任務執行的線程池 */ @Configuration public class TaskPoolConfig { @Bean("asyncExecutor1") public Executor taskExecutor1 () { ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor(); // 核心線程數10:線程池創建時候初始化的線程數 executor.setCorePoolSize(10); // 最大線程數20:線程池最大的線程數,只有在緩沖隊列滿了之后才會申請超過核心線程數的線程 executor.setMaxPoolSize(20); // 緩沖隊列200:用來緩沖執行任務的隊列 executor.setQueueCapacity(200); // 允許線程的空閑時間60秒:當超過了核心線程出之外的線程在空閑時間到達之后會被銷毀 executor.setKeepAliveSeconds(60); // 線程池名的前綴:設置好了之后可以方便定位處理任務所在的線程池 executor.setThreadNamePrefix("asyncTask1-"); /* 線程池對拒絕任務的處理策略:這里采用了CallerRunsPolicy策略, 當線程池沒有處理能力的時候,該策略會直接在 execute 方法的調用線程中運行被拒絕的任務; 如果執行程序已關閉,則會丟棄該任務 */ executor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy()); // 設置線程池關閉的時候等待所有任務都完成再繼續銷毀其他的Bean executor.setWaitForTasksToCompleteOnShutdown(true); // 設置線程池中任務的等待時間,如果超過這個時候還沒有銷毀就強制銷毀,以確保應用最后能夠被關閉,而不是阻塞住。 executor.setAwaitTerminationSeconds(600); return executor; } }
@EnableAsync // 啟用異步任務 @SpringBootApplication public class TaskApplication { public static void main(String[] args) { SpringApplication.run(TaskApplication.class,args) ; } }
@RestController public class TaskController { @Resource private AsyncTask asyncTask ; @RequestMapping("/asyncTask") public String asyncTask (){ asyncTask.asyncTask0(); asyncTask.asyncTask1(); return "success" ; } }
感謝各位的閱讀!關于“SpringBoot2如何使用定時任務和異步任務”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。