zoukankan      html  css  js  c++  java
  • Spring Cloud-为什么Eureka Client获取服务实例这么慢

    1. Eureka Client的注册延迟
      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();
     }
    
    1. Eureka Server的响应缓存
      Eureka Server每隔30s更新一次响应缓存, 可通过配置eureka.server.response-cache-update-interval-ms来修改, 所以即便是刚刚注册的服务实例, 也不会立即出现在注册列表中
    2. Eureka Client的缓存
      Eureka Client保留注册列表信息的缓存, 该缓存每隔30s去更新(向Eureka Server请求)一次, 因此, Eureka Client刷新本地缓存并发现其他服务实例的时间可能需要30s
    3. LoadBalancer的缓存
      Ribbon的负载平衡器从本地的Eureka Cient获取服务注册列表信息, Ribbon本身还维护了缓存, 以避免每个请求都需要从Eureka Client获取服务注册列表信息, 此缓存每隔30s刷新一次(可由ribbon的相关配置修改), 所以可能需要至少30s的时间才能使用新注册的实例

    综上因为, 一个新注册的实例, 默认延迟40s向服务中心注册, 所以不能马上被Eureka Server发现. 另外, 刚注册的Eureka Client也不能立即被其他服务调用, 原因是调用方由于各种缓存没有及时获取到最新的服务注册列表信息

  • 相关阅读:
    PHP:面向对象学习笔记,重点模拟Mixin(掺入)
    Mybatis Plus 更新
    Mybatis Plus 自定义SQL和分页插件
    Mybatis Plus 查询方法
    Mybatis Plus 快速入门
    Ribbon 负载均衡服务调用
    三个注册中心异同点
    Consul 服务注册与发现
    Spring Boot 集成 Swagger
    Eureka 服务注册与发现
  • 原文地址:https://www.cnblogs.com/no-celery/p/14191412.html
Copyright © 2011-2022 走看看