spring bean 加載 順序 接口 相關(guān)

以下所有實(shí)現(xiàn)均在springBoot 的環(huán)境下

和bean啟動(dòng)相關(guān)的接口有 以下接口按照bean 實(shí)例化過程中的先后順序書寫

spring 的接口

  • bean本身的構(gòu)造器 無參數(shù)
  • BeanNameAware ->得到bean 的名字 最先調(diào)用
  • BeanFactoryAware ->得到beanFactory
  • ApplicationContextAware --> 獲得 ApplicationContext
  • InitializingBean ------> bean 初始化完成 調(diào)用
  • BeanFactoryPostProcessor -------> 會(huì)在 InitializingBean 初始化后執(zhí)行鸯檬, 傳入 configurableListableBeanFactory,注意 此 接口 會(huì)影響 @PostConstruct 注解 調(diào)用
  • BeanPostProcessor
2017-11-07 19:50:38.458  INFO 38542 --- [  restartedMain] c.gxgeek.springfeaturesstudy.InitBean3   : bean3 初始化
2017-11-07 19:50:38.463  INFO 38542 --- [  restartedMain] c.gxgeek.springfeaturesstudy.InitBean3   : bean3 setBeanName
2017-11-07 19:50:38.464  INFO 38542 --- [  restartedMain] c.gxgeek.springfeaturesstudy.InitBean3   : bean3 setBeanFactory
2017-11-07 19:50:38.464  INFO 38542 --- [  restartedMain] c.gxgeek.springfeaturesstudy.InitBean3   : bean3 setApplicationContext
2017-11-07 19:50:38.464  INFO 38542 --- [  restartedMain] com.gxgeek.springfeaturesstudy.InitBean  : BeanPostProcessor 接口的: postProcessBeforeInitialization com.gxgeek.springfeaturesstudy.InitBean3@149fb594-->com.gxgeek.springfeaturesstudy.InitBean3
2017-11-07 19:50:38.464  INFO 38542 --- [  restartedMain] c.gxgeek.springfeaturesstudy.InitBean3   : bean3 postConstruct
2017-11-07 19:50:38.464  INFO 38542 --- [  restartedMain] c.gxgeek.springfeaturesstudy.InitBean3   : bean3 afterPropertiesSet
2017-11-07 19:50:38.464  INFO 38542 --- [  restartedMain] com.gxgeek.springfeaturesstudy.InitBean  : BeanPostProcessor 接口的: postProcessAfterInitializationcom.gxgeek.springfeaturesstudy.InitBean3@149fb594-->com.gxgeek.springfeaturesstudy.InitBean3

SpringBoot 的接口

  • CommandLineRunner 坷剧,ApplicationRunner 容器初始化完成之后開始調(diào)用run方法
    在 ==ContextRefreshedEvent== 事件 之后 在 ==ApplicationReadyEvent== 事件之后

spring 和springBoot 啟動(dòng)的事件

spirng 內(nèi)定事件

  • ContextStartedEvent 事件 // ==暫無發(fā)現(xiàn)任何默認(rèn)注冊(cè)監(jiān)聽==

  • ContextRefreshedEvent 事件 --->初始化完成上下文調(diào)用(現(xiàn)在只發(fā)現(xiàn)調(diào)用一次 )

  • ContextStoppedEvent 事件// ==暫無發(fā)現(xiàn)任何默認(rèn)注冊(cè)監(jiān)聽==

  • ContextClosedEvent 事件 ---> 調(diào)用ConfigurableApplicationContext的close方法的時(shí)候 應(yīng)用調(diào)用响禽。
    只調(diào)用一次

  • RequestHandledEvent 事件 ---> 請(qǐng)求完成調(diào)用(注意可能會(huì)調(diào)用多次 )

spirng Boot 內(nèi)定事件

spring-boot擴(kuò)展了spring的ApplicationContextEvent鳞溉,提供了四種事件

按照先后順序 開始執(zhí)行(這四個(gè)事件需要我們手動(dòng)去(addListeners()或?qū)懪渲梦募?)

多個(gè) 逗號(hào)分隔 context.listener.classes=com.gxgeek.springfeaturesstudy.SpringFeaturesStudyApplication.ApplicationListenerEnvironmentPrepared

去監(jiān)聽 不能通過 寫注解或者 去將類變成 bean 實(shí)現(xiàn) 其實(shí)很好理解 變成bean 之后必須 和context 上下文相關(guān)聯(lián) 但是已經(jīng)在上下文中 是不可能接收到 這些事件的)

  • ApplicationStartedEvent :spring boot啟動(dòng)開始時(shí)執(zhí)行的事件(==這個(gè)事件沒有觀察到== )
  • ApplicationEnvironmentPreparedEvent:spring boot 對(duì)應(yīng)Enviroment已經(jīng)準(zhǔn)備完畢胸嘴,但此時(shí)上下文context還沒有創(chuàng)建厕氨。
  • ApplicationPreparedEvent:spring boot上下文context創(chuàng)建完成枕稀,但此時(shí)spring中的bean是沒有完全加載完成的杀赢。(可以理解為 最先 注入的bean 可以拿到上下文 注意此時(shí)的上下文中其實(shí)是有少數(shù)的bean 的 三四個(gè)
  • ApplicationFailedEvent:spring boot啟動(dòng)異常時(shí)執(zhí)行事件
boot內(nèi)定的事件注冊(cè) 自定義bean (寫注解 或接口 變成bean 就可以觀察到)
  • ApplicationReadyEvent 應(yīng)用可以請(qǐng)求辨萍,意味著端口開始監(jiān)聽 執(zhí)行

總結(jié)

springBoot 啟動(dòng)先后調(diào)用

容器級(jí)別

ApplicationEnvironmentPreparedEvent 事件

ApplicationPreparedEvent 事件

bean 級(jí)別

  • bean本身的構(gòu)造器 無參數(shù)
  • BeanNameAware ->得到bean 的名字 最先調(diào)用
  • BeanFactoryAware ->得到beanFactory
  • ApplicationContextAware --> 獲得 ApplicationContext
  • @PostConstruct 注解執(zhí)行
  • InitializingBean ------> bean 初始化完成 調(diào)用
  • BeanFactoryPostProcessor -------> 會(huì)在 InitializingBean 初始化后執(zhí)行棋恼, 傳入 configurableListableBeanFactory,注意 此 接口 會(huì)影響 @PostConstruct 注解 調(diào)用
  • BeanPostProcessor

容器結(jié)束

ContextRefreshedEvent 事件 容器全部實(shí)例化完成

ApplicationRunner,CommandLineRunner 接口實(shí)現(xiàn) 執(zhí)行

ApplicationReadyEvent 事件 --> 可以接受請(qǐng)求發(fā)送該事件

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市锈玉,隨后出現(xiàn)的幾起案子爪飘,更是在濱河造成了極大的恐慌,老刑警劉巖拉背,帶你破解...
    沈念sama閱讀 211,376評(píng)論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件师崎,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡去团,警方通過查閱死者的電腦和手機(jī)抡诞,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,126評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門穷蛹,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人昼汗,你說我怎么就攤上這事肴熏。” “怎么了顷窒?”我有些...
    開封第一講書人閱讀 156,966評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵蛙吏,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我鞋吉,道長(zhǎng)鸦做,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,432評(píng)論 1 283
  • 正文 為了忘掉前任谓着,我火速辦了婚禮泼诱,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘赊锚。我一直安慰自己治筒,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,519評(píng)論 6 385
  • 文/花漫 我一把揭開白布舷蒲。 她就那樣靜靜地躺著耸袜,像睡著了一般。 火紅的嫁衣襯著肌膚如雪牲平。 梳的紋絲不亂的頭發(fā)上堤框,一...
    開封第一講書人閱讀 49,792評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音纵柿,去河邊找鬼蜈抓。 笑死,一個(gè)胖子當(dāng)著我的面吹牛藐窄,可吹牛的內(nèi)容都是我干的资昧。 我是一名探鬼主播,決...
    沈念sama閱讀 38,933評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼荆忍,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼格带!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起刹枉,我...
    開封第一講書人閱讀 37,701評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤叽唱,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后微宝,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體棺亭,經(jīng)...
    沈念sama閱讀 44,143評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,488評(píng)論 2 327
  • 正文 我和宋清朗相戀三年蟋软,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了镶摘。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片嗽桩。...
    茶點(diǎn)故事閱讀 38,626評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖凄敢,靈堂內(nèi)的尸體忽然破棺而出碌冶,到底是詐尸還是另有隱情,我是刑警寧澤涝缝,帶...
    沈念sama閱讀 34,292評(píng)論 4 329
  • 正文 年R本政府宣布扑庞,位于F島的核電站,受9級(jí)特大地震影響拒逮,放射性物質(zhì)發(fā)生泄漏罐氨。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,896評(píng)論 3 313
  • 文/蒙蒙 一滩援、第九天 我趴在偏房一處隱蔽的房頂上張望栅隐。 院中可真熱鬧,春花似錦狠怨、人聲如沸约啊。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,742評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至记盒,卻和暖如春憎蛤,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背纪吮。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評(píng)論 1 265
  • 我被黑心中介騙來泰國打工俩檬, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人碾盟。 一個(gè)月前我還...
    沈念sama閱讀 46,324評(píng)論 2 360
  • 正文 我出身青樓棚辽,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國和親冰肴。 傳聞我的和親對(duì)象是個(gè)殘疾皇子屈藐,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,494評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容