之前我们有介绍通过spring boot admin来检测服务的上下线,然后进行通知功能。 http://www.tuohang.net/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
查看更多关于Spring Cloud Eureka 服务上下线监控的实现的详细内容...