之前我们有介绍通过spring boot admin来检测服务的上下线,然后进行通知功能。
今天为大家介绍另外一种实现的方式,在eureka服务中进行检测通知,eureka中提供了事件监听的方式来支持扩展。
- eurekainstancecanceledevent 服务下线事件
- eurekainstanceregisteredevent 服务注册事件
- eurekainstancerenewedevent 服务续约事件
- eurekaregistryavailableevent eureka注册中心启动事件
- eurekaserverstartedevent eureka server启动事件
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集群环境下,每个节点都会触发事件,这个时候需要控制下发送通知的行为,不控制的话每个节点都会发送通知。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。
您可能感兴趣的文章:
如您对本文有疑问或者有任何想说的,请 点击进行留言回复,万千网友为您解惑!
网友评论