Несколько распространенных способов инициализации запуска проекта Springboot

описывать

	在项目启动的过程中执行一些指定的业务逻辑代码,初始化数据,加载某一个配置文件等等,所有在项目启动过程中需要自动执行的业务。

Сцены

Вот несколько сценариев, с которыми я столкнулся во время разработки:

  1. Если проект интегрирует другие сервисы, коллегам необходимо при старте запустить сервис, например: сервис Netty, построение сервиса ftp и так далее.
  2. Первоначальная настройка требуется при запуске проекта, например: инициализация определенного элемента информации или предварительная обработка определенного элемента информации.
  3. Запуск проекта должен взаимодействовать или читать конфигурацию с другими системами.

Способ 1. Реализуйте интерфейс ApplicationRunner, чтобы переписать логику метода запуска.

import org.springframework.boot.ApplicationArguments;
import org.springframework.boot.ApplicationRunner;
import org.springframework.stereotype.Component;

@Component
public class InitatialConfig implements ApplicationRunner {
    
    


    @Override
    public void run(ApplicationArguments args) throws Exception {
    
    
        System.out.println("项目启动初始化");
    }
}

вставьте сюда описание изображения

Способ 2. Реализуйте интерфейс CommandLineRunner, чтобы переписать логику метода запуска.

import org.springframework.boot.CommandLineRunner;
import org.springframework.stereotype.Component;

@Component
public class InitatialConfigCommand implements CommandLineRunner {
    
    



    @Override
    public void run(String... args) throws Exception {
    
    
        System.out.println("CommandLineRunner:"+"{}"+"接口实现方式重写");
    }
}

вставьте сюда описание изображения

Способ 3: использование аннотации @PostConstruct

    @PostConstruct
    public void testInitConfig(){
    
    

        System.out.println("@PostConstruct:"+"{}"+"注解方式实现启动初始化配置");
    }

вставьте сюда описание изображения

последовательность инициализации

  1. Метод аннотации @PostConstruct
  2. Реализация интерфейса CommandLineRunner
  3. Реализация интерфейса ApplicationRunner

Уведомление:

	当CommandLineRunner或者ApplicationRunner存在多个实现类的同时,可以使用@Order(1)注解进行顺序执行,该注解控制Bean的执行顺序。

Supongo que te gusta

Origin blog.csdn.net/A_awen/article/details/130647473
Recomendado
Clasificación