實際應用中,我們會有在項目服務啟動完成以后去加載一些數據或做一些事情(比如緩存)這樣的需求。
為了解決這樣的問題,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值從小到大順序。
