springboot 启动初始化数据

我们在开发中可能会有这样的情景。需要在容器启动的时候执行一些内容。比如读取配置文件,数据库连接之类的。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)。

猜你喜欢

转载自blog.csdn.net/pangpengshuai/article/details/76026538