實際應用中,我們會有在項目服務啟動完成以后去加載一些數據或做一些事情(比如緩存)這樣的需求。
為了解決這樣的問題,Spring Boot 為我們提供了一個方法,通過實現接口 CommandLineRunner 來實現。
很簡單,只需要一個類就可以,無需其他配置。
創建實現接口 CommandLineRunner 的類
@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 注解來定義執行順序。
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 <<<<<<<<<<<<<"); } }
啟動程序后,控制台輸出結果為:
>>>>>>>>>>>>>>>服務啟動執行,執行加載數據等操作 22222222 <<<<<<<<<<<<<
>>>>>>>>>>>>>>>服務啟動執行,執行加載數據等操作 11111111 <<<<<<<<<<<<<
根據控制台結果可判斷,@Order 注解的執行優先級是按value值從小到大順序。