Spring Cloud Eureka
创始人
2024-05-24 18:13:36
0

Eureka与CAP

不支持C,每个Eureka服务有三个缓存,数据同步有时间间隔,最差情况下,服务列表在30秒内不一致。
支持A,在Eureka集群中每个节点都是平等的,只要存在一个节点,就能保证注册服务可用性
支持P,因为有定时踢出和自我保护,即使Client没有续约上,其他Client也能从Server拉取到注册表信息

Eurekad的三级缓存

Eurekad的三级缓存分别是register,readWrtiteCacheMap,readOnlyCacheMap
源码中三个缓存分别使用的数据类型:

 private final ConcurrentHashMap>> registry= new ConcurrentHashMap>>();private final ConcurrentMap readOnlyCacheMap = new ConcurrentHashMap();private final LoadingCache readWriteCacheMap;

流程关系是当有服务注册进来时,会先注册到registry,同时如果readWrtiteCacheMap存在该服务,则让其失效。readOnlyCacheMap在于readWrtiteCacheMap定时同步,客户端拉取服务时默认先从readOnlyCacheMap取,如果没有再从readWrtiteCacheMap取,所以可以修改这个默认配置直接从readWrtiteCacheMap取

Eureka拉取实例信息的过程

客户端第一次全量拉取+后续增量拉取

eureka集群available-replicas不为空

Eureka处理available-replicas和unavailable-replicas信息的源码:

private boolean isReplicaAvailable(String url) {try {/**需要将以下配置设置为trueeureka.client.register-with-eureka=trueeureka.client.fetch-registry=true**/Application app = registry.getApplication(myAppName, false);if (app == null) {return false;}for (InstanceInfo info : app.getInstances()) {// 服务之间注册和接收到的地址要一致if (peerEurekaNodes.isInstanceURL(url, info)) {return true;}}} catch (Throwable e) {logger.error("Could not determine if the replica is available ", e);}return false;
}

Server优化

eureka:server:# 每 6 秒会检测失效的服务,也就是如果有服务超过 6 秒没有向Eureka Server 发起 Renew 请求的话,就会被当做失效服务剔除掉eviction-interval-timer-in-ms: 6000# 自我保护,服务较少的情况下关掉,服务较多的情况下可以开启,因为服务较多的情况下可能出现网络波动导致服务没有续约上enable-self-preservation: false# 自我保护阈值,默认0.85,表示如果有100个服务掉了15个服务就会开启自我保护,后面没收到心跳包的Client不会被踢出renewal-percent-threshold: 0.85# 关闭从readOnly读注册表use-read-only-response-cache: false

Client优化

eureka:client:service-url:# 向Eureka Server的注册地址,在集群情况下需要将注册地址打乱,不然压力都会在第一个地址的服务器下defaultZone: http://localhost:8000/eureka# 刷新注册表( 拉取注册表 )间隔,默认30秒registry-fetch-interval-seconds: 5instance:# 心跳续约间隔lease-renewal-interval-in-seconds: 10# 心跳过期时间lease-expiration-duration-in-seconds: 10

上一篇:WeNet - 初识

下一篇:如何上传文件

相关内容

热门资讯

喜欢穿一身黑的男生性格(喜欢穿... 今天百科达人给各位分享喜欢穿一身黑的男生性格的知识,其中也会对喜欢穿一身黑衣服的男人人好相处吗进行解...
发春是什么意思(思春和发春是什... 本篇文章极速百科给大家谈谈发春是什么意思,以及思春和发春是什么意思对应的知识点,希望对各位有所帮助,...
网络用语zl是什么意思(zl是... 今天给各位分享网络用语zl是什么意思的知识,其中也会对zl是啥意思是什么网络用语进行解释,如果能碰巧...
为什么酷狗音乐自己唱的歌不能下... 本篇文章极速百科小编给大家谈谈为什么酷狗音乐自己唱的歌不能下载到本地?,以及为什么酷狗下载的歌曲不是...
华为下载未安装的文件去哪找(华... 今天百科达人给各位分享华为下载未安装的文件去哪找的知识,其中也会对华为下载未安装的文件去哪找到进行解...
怎么往应用助手里添加应用(应用... 今天百科达人给各位分享怎么往应用助手里添加应用的知识,其中也会对应用助手怎么添加微信进行解释,如果能...
家里可以做假山养金鱼吗(假山能... 今天百科达人给各位分享家里可以做假山养金鱼吗的知识,其中也会对假山能放鱼缸里吗进行解释,如果能碰巧解...
四分五裂是什么生肖什么动物(四... 本篇文章极速百科小编给大家谈谈四分五裂是什么生肖什么动物,以及四分五裂打一生肖是什么对应的知识点,希...
一帆风顺二龙腾飞三阳开泰祝福语... 本篇文章极速百科给大家谈谈一帆风顺二龙腾飞三阳开泰祝福语,以及一帆风顺二龙腾飞三阳开泰祝福语结婚对应...
美团联名卡审核成功待激活(美团... 今天百科达人给各位分享美团联名卡审核成功待激活的知识,其中也会对美团联名卡审核未通过进行解释,如果能...