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