實際應用中,咱們會有在項目服務啓動完成之後去加載一些數據或作一些事情(好比緩存)這樣的需求。
爲了解決這樣的問題,Spring Boot 爲咱們提供了一個方法,經過實現接口 CommandLineRunner 來實現。java
很簡單,只須要一個類就能夠,無需其餘配置。
建立實現接口 CommandLineRunner 的類spring
@Bean public CommandLineRunner newEnumDataPreloadRunner() { return new EnumDataPreloadRunner(); } @Slf4j public class EnumDataPreloadRunner implements CommandLineRunner { @Resource private EnumDataUtil enumDataUtil; @Override public void run(String... args) throws Exception { CompletableFuture.runAsync(() -> log.info("preload over... types={}", this.enumDataUtil.refresh())) .toCompletableFuture(); } }
Spring Boot應用程序在啓動後,會遍歷CommandLineRunner接口的實例並運行它們的run方法。也能夠利用@Order註解(或者實現Order接口)來規定全部CommandLineRunner實例的運行順序。緩存
以下咱們使用@Order 註解來定義執行順序。springboot
package org.springboot.sample.runner; import org.springframework.boot.CommandLineRunner; import org.springframework.core.annotation.Order; import org.springframework.stereotype.Component; /** * 服務啓動執行 */ @Component @Order(value=2) public class MyStartupRunner1 implements CommandLineRunner { @Override public void run(String... args) throws Exception { System.out.println(">>>>>>>>>>>>>>>服務啓動執行,執行加載數據等操做 11111111 <<<<<<<<<<<<<"); } } package org.springboot.sample.runner; import org.springframework.boot.CommandLineRunner; import org.springframework.core.annotation.Order; import org.springframework.stereotype.Component; /** * 服務啓動執行 */ @Component @Order(value=1) public class MyStartupRunner2 implements CommandLineRunner { @Override public void run(String... args) throws Exception { System.out.println(">>>>>>>>>>>>>>>服務啓動執行,執行加載數據等操做 22222222 <<<<<<<<<<<<<"); } }
啓動程序後,控制檯輸出結果爲:ide
>>>>>>>>>>>>>>>服務啓動執行,執行加載數據等操做 22222222 <<<<<<<<<<<<<
>>>>>>>>>>>>>>>服務啓動執行,執行加載數據等操做 11111111 <<<<<<<<<<<<<this
根據控制檯結果可判斷,@Order 註解的執行優先級是按value值從小到大順序。blog