之前我們有介紹通過spring boot admin來檢測服務的上下線,然后進行通知功能。http://www.ythuaji.com.cn/article/145057.html
今天為大家介紹另外一種實現的方式,在eureka服務中進行檢測通知,eureka中提供了事件監聽的方式來支持擴展。
- eurekainstancecanceledevent 服務下線事件
- eurekainstanceregisteredevent 服務注冊事件
- eurekainstancerenewedevent 服務續約事件
- eurekaregistryavailableevent eureka注冊中心啟動事件
- eurekaserverstartedevent eureka server啟動事件
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
import com.netflix.appinfo.instanceinfo; import org.springframework.cloud.netflix.eureka.server.event.*; import org.springframework.context.event.eventlistener; import org.springframework.stereotype.component; /** * eureka事件監聽 * * @author yinjihuan * @create 2018-03-09 13:45 **/ @component public class eurekastatechangelistener { @eventlistener public void listen(eurekainstancecanceledevent event) { system.err.println(event.getserverid() + "\t" + event.getappname() + " 服務下線" ); } @eventlistener public void listen(eurekainstanceregisteredevent event) { instanceinfo instanceinfo = event.getinstanceinfo(); system.err.println(instanceinfo.getappname() + "進行注冊" ); } @eventlistener public void listen(eurekainstancerenewedevent event) { system.err.println(event.getserverid() + "\t" + event.getappname() + " 服務進行續約" ); } @eventlistener public void listen(eurekaregistryavailableevent event) { system.err.println( "注冊中心 啟動" ); } @eventlistener public void listen(eurekaserverstartedevent event) { system.err.println( "eureka server 啟動" ); } } |
上面只是演示事件的效果,具體在什么事件中需要做什么操作,需要發郵件還是發短信,需要大家自己去實現。
注意:在eureka集群環境下,每個節點都會觸發事件,這個時候需要控制下發送通知的行為,不控制的話每個節點都會發送通知。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。
原文鏈接:http://cxytiandi.com/blog/detail/17640