我们在开发中可能会有这样的情景。需要在容器启动的时候执行一些内容。比如读取配置文件,数据库连接之类的。SpringBoot给我们提供了两个接口来帮助我们实现这种需求。这两个接口分别为CommandLineRunner和ApplicationRunner。他们的执行时机为容器启动完成的时候。
代码如下:
package com.jb.mpc.equipmemnt.config;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.boot.ApplicationArguments;
import org.springframework.boot.ApplicationRunner;
import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;
import com.jb.mpc.controller.EquipmentController;
/**
* @see @Order注解的执行优先级是按value值从小到大顺序。
* @author pangps
* @version v1.0
* @date 2017年7月24日
*
*/
@Component
@Order(value=1)
public class MyApplicationRunner implements ApplicationRunner{
private static final Logger logger = LoggerFactory.getLogger(MyApplicationRunner.class);
@Override
public void run(ApplicationArguments args) throws Exception {
logger.info("==服务启动后,初始化数据操作==");
}
}
package com.jb.mpc.equipmemnt.config;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.boot.CommandLineRunner;
import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;
/**
* @see @Order注解的执行优先级是按value值从小到大顺序。
* @author pangps
* @version v1.0
* @date 2017年7月24日
*
*/
@Component
@Order(value=2)
public class MyCommandLineRunner implements CommandLineRunner{
private static final Logger logger = LoggerFactory.getLogger(MyCommandLineRunner.class);
@Override
public void run(String... args) throws Exception {
logger.info("==服务启动执行,执行加载数据等操作==");
}
}
运行结果:
说明:
1、@Order注解
如果有多个实现类,而你需要他们按一定顺序执行的话,可以在实现类上加上@Order注解。@Order(value=整数值)。SpringBoot会按照@Order中的value值从小到大依次执行。
2、如果你发现你的实现类没有按照你的需求执行,请看一下实现类上是否添加了Spring管理的注解(@Component)。