源码地址: https://gitee.com/bingqilinpe...
上篇文章中,经过代码搭建了Eureka注册中心和客户端,是Eureka的简单应用,在本文中将会讲解更多关于Eureka服务端的应用以及原理。git
在使用Eureka的过程当中,有时候会在Eureka服务端的页面上看到以下的内容:面试
在监控页面上会看到一行红字儿,这些红字儿什么意思呢?表明着Eureka注册中心进入了自我保护机制。spring
默认状况下,若是Eureka Server在必定时间内没有接受到服务实例的心跳,Eureka将会注销该实例(默认90秒).可是当网络分区发生故障时,微服务客户端和Eureka Server 没法正常通讯。以上行为可能变得特别危险了,由于微服务自己是健康的,此时不能注销该服务实例。segmentfault
Eureka经过自我保护机制来解决这个问题,当Eureka Server在短期丢失过多的服务实例(可能发生了网络分区的故障),那么Eureka Server进入自我保护模式,一旦进入此模式,Eureka Server将会保护服务注册表中的信息,再也不删除服务注册表中的数据(也就是再也不注销任何的服务实例),当网络故障恢复后,Eureka Server会自动退出自我保护模式。安全
综上,自我保护模式是一种应对网络故障的安全保护措施,它的架构哲学是宁肯同时保留全部的微服务,也不盲目注销任何健康的微服务,使用自我保护模式可让Eureka,更加健壮,稳定。网络
一句话:大面积出现客户端失联的时候,Eureka 注册中心进入自我保护模式,不注销任何实例
在Eureka Server中配置关闭自我保护机制架构
#关闭自我保护机制 默认开启 eureka.server.enable-self-preservation=false
若是想及时剔除失效的eureka服务除了关闭自我保护机制外,能够调低eureka的心跳值微服务
eureka-server服务端 配置文件中咱们添加以下配置 #关闭保护机制,以确保注册中心将不可用的实例正确剔除 eureka.server.enable-self-preservation=false #(表明是5秒,单位是毫秒,清理失效服务的间隔 ) eureka.server.eviction-interval-timer-in-ms=5000
客户端 配置文件中咱们添加以下配置 # 心跳检测检测与续约时间 # 测试时将值设置设置小些,保证服务关闭后注册中心能及时踢出服务 # 配置说明 # lease-renewal-interval-in-seconds 每间隔10s,向服务端发送一次心跳,证实本身依然”存活“ # lease-expiration-duration-in-seconds 告诉服务端,若是我20s以内没有给你发心跳,就表明我“死”了,将我踢出掉。 eureka.instance.lease-renewal-interval-in-seconds=10 eureka.instance.lease-expiration-duration-in-seconds=20
注册中心集群 防止单点故障学习
Eureka能够经过运行多个实例并互相注册实现高可用部署,Eureka Server实例会彼此同步信息。测试
Tips:代码在前上篇教程的基础上开发,源码地址:https://gitee.com/bingqilinpe...
1.建立第二个Eureka服务端 eureka-server-8800
2.修改pom文件
3.建立并修改启动类
package com.lby; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer; /** * @author luxiaoyang * @create 2020-03-30-20:36 */ @EnableEurekaServer @SpringBootApplication public class EurekaServer8800 { public static void main(String[] args) { SpringApplication.run(EurekaServer8800.class,args); } }
4.写配置文件
5.修改注册中心eureka-server-8801的配置文件
注册中心之间的基本逻辑是:互相注册
此时咱们就拥有了一个Eureka注册中心的集群
6.修改全部客户端的配置,客户端须要向 注册中心集群注册 因此须要配置全部注册中心的地址
1.启动全部的注册中心和客户端
2.查看Eureka注册中心管理页面
查看注册中心 8800 的管理页面,能够看到客户端能够正常注册
查看注册中心 8801 的管理页面,能够看到客户端也能够正常注册
3.关闭一个注册中心8800,注册中心8801不受任何影响,整个微服务的集群也不受任何影响,客户端能够正常注册
以上就是Eureka注册中心高可用和自我保护机制的相关内容。
源码地址: https://gitee.com/bingqilinpe...
恭喜你完成了本章的学习,为你鼓掌!若是本文对你有帮助,请帮忙点赞,评论,转发,这对做者很重要,谢谢。
要掌握SpringCloud更多的用法,请持续关注本系列教程。
欢迎关注本人公众号:鹿老师的Java笔记,将在长期更新Java技术图文教程和视频教程,Java学习经验,Java面试经验以及Java实战开发经验。