前言
本文主要給大家介紹了關于spring boot應用事件監聽的相關內容,分享出來供大家參考學習,下面話不多說了,來一起看看詳細的介紹吧
1. spring boot特有的應用事件
除了spring框架的事件,spring boot的springapplication也發送了一些自己的事件:
- applicationstartingevent:在任何處理(除了注冊listener和initializer)開始之前發送。
- applicationenvironmentpreparedevent: 在context創建之前,而用到context中的environment已經被識別時發送。
- applicationcontextinitializedevent: springapplication正在啟動,applicationcontext已準備好且applicationcontextinitializer已被調用但是bean的定義還沒有被加載時發送。
- applicationpreparedevent: 在context刷新之前,在bean的定義已經被加載之后調用。
- applicationstartedevent: 在任何應用和command-line runner調用之前,而context已經被刷新時發送。
- applicationreadyevent: 在任何應用和command-line runner被調用的時候發送,它意味著應用可以接受請求了。
- applicationfailedevent: 在啟動時有異常的時候發送。
有些事件是在applicationcontext創建之前觸發的,所以我們不能用常規的注冊成bean的事件監聽方式:
- 注解了@eventlistener注解分方法的類注冊的bean;
- 實現了applicationlistener<event>接口的類注冊的bean。
像applicationstartedevent和applicationreadyevent是applicationcontext創建之后觸發的,可以用上述兩種方式來監聽事件。
2. 如何監聽這些事件
我們可以通過下面的方式注冊監聽:
2.1. springapplication.addlisteners(...)
1
2
3
4
5
6
7
8
9
10
|
springapplication application = new springapplication(starteventsapplication. class ); application.addlisteners( (applicationlistener<applicationstartingevent>) event -> log.info( "----------- 監聽spring boot:" + event.getclass().getsimplename()), (applicationlistener<applicationenvironmentpreparedevent>) event -> log.info( "----------- 監聽spring boot:" + event.getclass().getsimplename()), (applicationlistener<applicationcontextinitializedevent>) event -> log.info( "----------- 監聽spring boot:" + event.getclass().getsimplename()), (applicationlistener<applicationpreparedevent>) event -> log.info( "----------- 監聽spring boot:" + event.getclass().getsimplename()), (applicationlistener<applicationstartedevent>) event -> log.info( "----------- 監聽spring boot:" + event.getclass().getsimplename()), (applicationlistener<applicationreadyevent>) event -> log.info( "----------- 監聽spring boot:" + event.getclass().getsimplename()) ); application.run(args); |
2.2. springapplicationbuilder.listeners(...)
1
2
3
4
5
6
7
8
9
10
11
|
new springapplicationbuilder() .sources(starteventsapplication. class ) .listeners( (applicationlistener<applicationstartingevent>) event -> log.info( "----------- 監聽spring boot:" + event.getclass().getsimplename()), (applicationlistener<applicationenvironmentpreparedevent>) event -> log.info( "----------- 監聽spring boot:" + event.getclass().getsimplename()), (applicationlistener<applicationcontextinitializedevent>) event -> log.info( "----------- 監聽spring boot:" + event.getclass().getsimplename()), (applicationlistener<applicationpreparedevent>) event -> log.info( "----------- 監聽spring boot:" + event.getclass().getsimplename()), (applicationlistener<applicationstartedevent>) event -> log.info( "----------- 監聽spring boot:" + event.getclass().getsimplename()), (applicationlistener<applicationreadyevent>) event -> log.info( "----------- 監聽spring boot:" + event.getclass().getsimplename()) ) .run(args); |
2.3. meta-inf/spring.factories
src/main/resources/meta-inf/spring.factories:
1
2
3
4
5
6
|
org.springframework.context.applicationlistener=top.wisely.startevents.listeners.applicationcontextinitializedeventlistener, \ top.wisely.startevents.listeners.applicationenvironmentpreparedeventlistener, \ top.wisely.startevents.listeners.applicationpreparedeventlistener, \ top.wisely.startevents.listeners.applicationreadyeventlistener, \ top.wisely.startevents.listeners.applicationstartedeventlistener, \ top.wisely.startevents.listeners.applicationstartingeventlistener |
監聽器只需實現applicationlistener<要監聽的接口類型>接口,無需手動注冊為bean:
1
2
3
4
5
6
|
public class applicationstartedeventlistener implements applicationlistener<applicationstartedevent> { @override public void onapplicationevent(applicationstartedevent event) { log.info( "----------- 監聽spring boot:" + event.getclass().getsimplename()); } } |
3. 源碼地址
https://github.com/wiselyman/spring-boot-application-events.git
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對服務器之家的支持。
原文鏈接:http://www.wisely.top/2018/12/04/spring-boot-application-events/