日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

Spring Boot————应用启动时的监听机制测试

發(fā)布時(shí)間:2025/3/12 javascript 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Spring Boot————应用启动时的监听机制测试 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

引言

本文承接前面的《Spring Boot————Spring Boot啟動(dòng)流程分析》,主要測試一下ApplicationContextInitializerSpringApplicationRunListenerApplicationRunnerCommandLineRunner這四個(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:
public class MyApplicationContextInitializer implements ApplicationContextInitializer<ConfigurableApplicationContext> {@Overridepublic void initialize(ConfigurableApplicationContext applicationContext) {System.out.println("MyApplicationContextInitializer...initialize..." + applicationContext);} }
  • 實(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:
@Component public class MyApplicationRunner implements ApplicationRunner{@Overridepublic void run(ApplicationArguments args) throws Exception {System.out.println("MyApplicationRunner...run...");} }
  • ?實(shí)現(xiàn)CommandLineRunner:
@Component public class MyCommandLineRunner implements CommandLineRunner {@Overridepublic void run(String... args) throws Exception {System.out.println("MyCommandLineRunner...run..." + Arrays.asList(args));} }

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)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。