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也不能立即被其他服务调用, 原因是调用方由于各种缓存没有及时获取到最新的服务注册列表信息

  • 相关阅读:
    sqli-labs lexx25-28a(各种过滤)
    sqli-labs less-24(二次注入)
    sqli-labs less13-20(各种post型头部注入)
    sql注入之双查询注入
    sqli-labs less11-12(post型union注入)
    sqli-labs less8-10(布尔盲注时间盲注)
    sqli-labs less-7(文件读写)
    Vue ref childNode 坑
    Blob
    中文输入法不触发onkeyup事件的解决办法Script
  • 原文地址:https://www.cnblogs.com/no-celery/p/14191412.html
Copyright © 2011-2022 走看看