按照指定時間執行的程序。java
數據分析 數據清理 系統服務監控
同步調用
程序按照代碼順序依次執行,每一行程序都必須等待上一行程序執行完成以後才能執行;
異步調用
順序執行時,不等待異步調用的代碼塊返回結果就執行後面的程序。git
短信通知 郵件發送 批量數據入緩存
@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======"); } }
這裏能夠不指定,指定執行的線城池,能夠更加方便的監控和管理異步任務的執行。github
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" ; } }
GitHub地址:知了一笑 https://github.com/cicadasmile/spring-boot-base 碼雲地址:知了一笑 https://gitee.com/cicadasmile/spring-boot-base