实际应用中,咱们会有在项目服务启动完成之后去加载一些数据或作一些事情(好比缓存)这样的需求。
为了解决这样的问题,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