不得不知的Spring Boot與Spring Cloud應(yīng)用啟動(dòng)流程
在繼續(xù)分析Spring Cloud實(shí)現(xiàn)動(dòng)態(tài)配置的源碼之前,我們需要補(bǔ)充一些Spring Boot和Spring Cloud的基礎(chǔ)知識(shí)才能繼續(xù)往下看。本篇我們一起學(xué)習(xí)Spring Boot與Spring Cloud應(yīng)用的啟動(dòng)流程。
SpringBoot應(yīng)用啟動(dòng)流程
當(dāng)我們?cè)赟pring Boot項(xiàng)目中調(diào)用SpringApplication的run方法啟動(dòng)應(yīng)用時(shí),Spring Boot應(yīng)用啟動(dòng)流程粗粒度可劃分為三個(gè)步驟。
第一步:準(zhǔn)備環(huán)境Environment。此時(shí)會(huì)發(fā)送一個(gè)ApplicationEnvironmentPreparedEvent事件(應(yīng)用環(huán)境準(zhǔn)備事件),事件是同步消費(fèi)的。當(dāng)事件監(jiān)聽(tīng)器都被調(diào)用完后,Spring Boot繼續(xù)完成環(huán)境Environment的準(zhǔn)備工作,加載application.yaml以及所有的ActiveProfiles對(duì)應(yīng)的application-[activeProfile].yaml配置文件。
第二步:準(zhǔn)備ApplicationContext容器。我們?cè)趕pring.factories文件中配置的EnableAutoConfiguration就是在此時(shí)被讀取的,并且根據(jù)配置的類(lèi)名加載類(lèi),為類(lèi)生成BeanDefinition注冊(cè)到bean工廠中。
第三步:一切準(zhǔn)備就緒后再刷新ApplicationContext。
Spring Boot啟動(dòng)流程如下圖所示。
Spring Cloud應(yīng)用啟動(dòng)流程
Spring Cloud項(xiàng)目可以在spring.factories配置文件中配置一種BootstrapConfiguration類(lèi),這與Spring Boot提供的EnableAutoConfiguration類(lèi)并沒(méi)有什么區(qū)別,只是它們作用在不同的ApplicationContext容器中。
當(dāng)項(xiàng)目中添加Spring Cloud的依賴(lài)時(shí),SpringApplication的run方法啟動(dòng)的就會(huì)是兩個(gè)容器,即兩個(gè)ApplicationContext。原本的應(yīng)用啟動(dòng)流程也有所變化。
Spring Cloud的BootstrapApplicationListener監(jiān)聽(tīng)ApplicationEnvironmentPreparedEvent事件,在監(jiān)聽(tīng)到事件時(shí)開(kāi)啟一個(gè)新的ApplicationContext容器,我們可以稱(chēng)這個(gè)ApplicationContext容器為Spring Cloud的Bootstrap容器。
Bootstrap容器被用來(lái)注冊(cè)spring.factories配置文件中配置的所有BootstrapConfiguration,并在Bootstrap容器初始化完成后將其Bean工廠作為原本Spring Boot啟動(dòng)的ApplicationContext容器的Bean工廠的父工廠,如下圖所示。
這個(gè)Spring Cloud層的Bootstrap容器似乎是Spring Cloud特定為實(shí)現(xiàn)動(dòng)態(tài)配置量身定做的。
Spring Cloud的啟動(dòng)流程如下圖所示。
Spring Cloud創(chuàng)建為應(yīng)用啟動(dòng)一個(gè)Bootstrap容器也會(huì)走一遍Spring Boot應(yīng)用的啟動(dòng)流程。而原來(lái)main方法中調(diào)用SpringApplication的run方法啟動(dòng)ApplicationContext容器則會(huì)卡在環(huán)境準(zhǔn)備階段,等待Spring Cloud為其提供父工廠。
bootstrap.[yaml|props]配置文件在BootstrapApplicationListener監(jiān)聽(tīng)到ApplicationEnvironmentPreparedEvent事件時(shí),準(zhǔn)備啟動(dòng)Bootstrap容器之前讀取,并寫(xiě)入到Bootstrap容器的Environment。
BootstrapApplicationListener通過(guò)判斷Environment中是否存在bootstrap這個(gè)PropertySource辨別當(dāng)前容器是否是Bootstrap容器,以解決無(wú)限監(jiān)聽(tīng)到ApplicationEnvironmentPreparedEvent事件啟動(dòng)新容器的問(wèn)題。
本文轉(zhuǎn)載自微信公眾號(hào)「 Java藝術(shù)」,可以通過(guò)以下二維碼關(guān)注。轉(zhuǎn)載本文請(qǐng)聯(lián)系Java藝術(shù)公眾號(hào)。