java、springboot项目启动时初始化的几种方式

springboot项目启动时初始化的几种方式

    • 1、ApplicationRunner
    • 2、@PostConstruct
    • 3、InitializingBean

1、ApplicationRunner

对于springboot项目我们可以采用实现ApplicationRunner类来进行初始化,方法也很简单,直接在run方法中写下你要执行的初始化代码就行。该方法比@PostConstruct注解要慢。

// An highlighted block
package config;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.boot.ApplicationArguments;
import org.springframework.boot.ApplicationRunner;
import org.springframework.stereotype.Component;


/**
 * @author Damon-z
 * @date 2019/8/6 17:30
 */
@Component
public class InitConfig implements ApplicationRunner {
    private static final Logger log = LoggerFactory.getLogger(InitConfig.class);
    @Override
    public void run(ApplicationArguments args) {
        log.info("项目启动初始化开始ApplicationRunner");
        Util.init();
        log.info("项目启动初始化结束ApplicationRunner");
    }
}

根据日志可以看出ApplicationRunner 是在started之后初始化的在这里插入图片描述

2、@PostConstruct

该注解也是在项目过程中执行初始化的作用。比ApplicationRunner要快。所以在使用

// An highlighted block
package config;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import javax.annotation.PostConstruct;

/**
 * @author Damon-z
 */
@SpringBootApplication
public class ProjectApplication {
    private static final Logger log = LoggerFactory.getLogger(ProjectApplication .class);
    public static void main(String[] args) {
        SpringApplication.run(ProjectApplication.class, args);
    }

    @PostConstruct
    public void init() {
        log.info("初始化方法开始PostConstruct");
       //Util.init();
        log.info("初始化方法结束PostConstruct");
    }

}

从日志可以看出@PostConstruct在加载servlet是初始化的,因此比ApplicationRunner 要快
java、springboot项目启动时初始化的几种方式_第1张图片

3、InitializingBean

该方法速度与@PostConstruct一样,实现方法也很简单,

// An highlighted block
package config;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.InitializingBean;

/**
 * @author Damon-z
 * @date 2019/8/11 20:34
 */
public class InitBean implements InitializingBean {
    private static final Logger log = LoggerFactory.getLogger(InitConfig.class);
    @Override
    public void afterPropertiesSet() {
        log.info("项目启动初始化开始InitializingBean");
        Util.init();
        log.info("项目启动初始化结束InitializingBean");
    }
}

以上几种方式,InitializingBean 是不用springboot就能实现的。但是如果我们要在初始化过程中使用静态static的方法块并调用静态变量时,应采用ApplicationRunner。比如说使用@Value加载配置文件的属性要设置为静态变量时,并要使用该静态变量进行初始化操作时要采用如下方法:

// An highlighted block
    private static String url;
    @Value("${util.url}")
    public void setUrl(String url) {
        Util.url= url;
    }
	 /**
     * 初始化连接
     */
    public static void  init(){
        //在静态方法中调用时是加载不到url的值的。
        System.out.println(url);
        //输出为null,所以要在项目中实现ApplicationRunner接口的run方法调用该方法进行相应的初始化操作。
    }

如有错误,请留言告诉博主修改!!!可以加博主微信zuo995518

你可能感兴趣的:(Java,Springboot)