Spring Cloud-为什么Eureka Client获取服务实例这么慢
2021-03-08 23:27
标签:config 并发 space tar inf dba 信息 return 原因 综上因为, 一个新注册的实例, 默认延迟40s向服务中心注册, 所以不能马上被Eureka Server发现. 另外, 刚注册的Eureka Client也不能立即被其他服务调用, 原因是调用方由于各种缓存没有及时获取到最新的服务注册列表信息 Spring Cloud-为什么Eureka Client获取服务实例这么慢 标签:config 并发 space tar inf dba 信息 return 原因 原文地址:https://www.cnblogs.com/no-celery/p/14191412.html
Eureka Client启动之后, 不是立即向Eureka Server注册的, 而是有一个延迟的向服务端注册的时间, 通过源码, 可以发现默认的延迟时间是40s, 源码在eureka-client-xx.jar的DufaultEurekaClientConfig类中, 代码如下: public int getInitialInstanceInfoReplicationIntervalSeconds() {
return this.configInstance.getIntProperty(this.namespace + "appinfo.initial.replicate.time", 40).get();
}
Eureka Server每隔30s更新一次响应缓存, 可通过配置eureka.server.response-cache-update-interval-ms来修改, 所以即便是刚刚注册的服务实例, 也不会立即出现在注册列表中
Eureka Client保留注册列表信息的缓存, 该缓存每隔30s去更新(向Eureka Server请求)一次, 因此, Eureka Client刷新本地缓存并发现其他服务实例的时间可能需要30s
Ribbon的负载平衡器从本地的Eureka Cient获取服务注册列表信息, Ribbon本身还维护了缓存, 以避免每个请求都需要从Eureka Client获取服务注册列表信息, 此缓存每隔30s刷新一次(可由ribbon的相关配置修改), 所以可能需要至少30s的时间才能使用新注册的实例
文章标题:Spring Cloud-为什么Eureka Client获取服务实例这么慢
文章链接:http://soscw.com/essay/62022.html