javascript
Spring Boot————应用启动时的监听机制测试
引言
本文承接前面的《Spring Boot————Spring Boot啟動流程分析》,主要測試一下ApplicationContextInitializer、SpringApplicationRunListener、ApplicationRunner、CommandLineRunner這四個接口實現之下的組件是何時在Spring Boot項目啟動時創建并執行相關方法的。
應用測試使用的是Spring Boot版本是2.0.6:
測試步驟
1、實現四個接口
這四個接口提供了在Spring 容器啟動前后相關的操作方法,我們通過實現這些接口,可以查看相關的執行流程,為日后業務中需要在啟動時執行的工作做好理論基礎。
在這四個接口中,ApplicationContextInitializer、ApplicationRunner、CommandLineRunner都是只有一個抽象方法需要被實現,因此,在Spring 啟動過程之中,也只會在某個時刻執行一次;而SpringApplicationRunListener的方法貫穿了整個spring啟動的始終。
- 實現ApplicationContextInitializer:
- 實現SpringApplicationRunListener
注意,SpringApplicationRunListener的實現類要求必須具備一個有參構造,否則會啟動報錯,具體可以參考該接口的另一個實現類:EventPublishingRunListener。
public class MySpringApplicationRunListener implements SpringApplicationRunListener {public MySpringApplicationRunListener(SpringApplication application, String[] args) {// SpringApplicationRunListener 的實現類要求必須具備有參構造}@Overridepublic void starting() {System.out.println("MySpringApplicationRunListener...starting...");}@Overridepublic void environmentPrepared(ConfigurableEnvironment environment) {Object osName = environment.getSystemProperties().get("os.name");System.out.println("MySpringApplicationRunListener...environmentPrepared..." + osName);}@Overridepublic void contextPrepared(ConfigurableApplicationContext context) {System.out.println("MySpringApplicationRunListener...contextPrepared...");}@Overridepublic void contextLoaded(ConfigurableApplicationContext context) {System.out.println("MySpringApplicationRunListener...contextLoaded...");}@Overridepublic void started(ConfigurableApplicationContext context) {System.out.println("MySpringApplicationRunListener...started...");}@Overridepublic void running(ConfigurableApplicationContext context) {System.out.println("MySpringApplicationRunListener...running...");}@Overridepublic void failed(ConfigurableApplicationContext context, Throwable exception) {System.out.println("MySpringApplicationRunListener...failed...");} }- 實現ApplicationRunner:
- ?實現CommandLineRunner:
2、配置組件
在第一步中,我們已經通過實現了四個接口,定義了四個自定義的組件,按照順序,以此為:MyApplicationContextInitializer、MySpringApplicationRunListener、MyApplicationRunner、MyCommandLineRunner。
那么根據《Spring Boot————Spring Boot啟動流程分析》中的描述,前兩個組件是需要配置到類路徑下的META-INF/spring.factories配置文件中的,因此,我們可以在 “src/main/resources” 文件夾下添加一個META-INF文件夾,然后新建一個spring.factories文件,并添加下面內容:
# Initializers org.springframework.context.ApplicationContextInitializer=\ com.example.demo.startup.MyApplicationContextInitializer# Application Listeners org.springframework.boot.SpringApplicationRunListener=\ com.example.demo.startup.MySpringApplicationRunListener而后兩個組件:?MyApplicationRunner 和?MyCommandLineRunner,則可以通過@Component注解,直接注入到 IOC容器中即可,第一步的代碼中也已經標記。
3、啟動項目
配置好四個組件之后,我們來啟動項目,觀察執行結果:
?上面兩個截圖,已經看到輸出了不同的打印日志,可以看到他們執行的先后順序都是怎樣的。
綜上,就是關于對項目應用啟動時的相關描述和測試,歡迎大家文末留言。
總結
以上是生活随笔為你收集整理的Spring Boot————应用启动时的监听机制测试的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: MySQL 基础————常用数据类型
- 下一篇: Docker必备知识整理