V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
sakudie
V2EX  ›  程序员

Spring Cloud Eureka 自我保护模式下 是否还会调用实际已经挂掉的服务

  •  
  •   sakudie · 2018-06-27 16:08:40 +08:00 · 4438 次点击
    这是一个创建于 2101 天前的主题,其中的信息可能已经有所发展或是发生改变。

    初步学习spring cloud, 所以部署了下程序运行看看。

    3 个服务提供者,一个消费者, 采用 Feign 调用方式

    一开始程序运行正常,轮询调用 3 个服务提供者,但是当我手动终止一个服务提供者后, 过了一会访问 Eureka 的管理界面,就可以看到进入了自我保护模式,但是服务提供者那里会一直仍然显示 UP(3)

    因为自我保护状态下是不会注销实例的, 所以我的问题是这个情况下,consumer 还会由于轮询负载均衡,调用到挂掉的服务提供者 吗? Eureka Client 应该是有缓存的,它关于处理保护状态下的实例的缓存又是什么机制?

    2 条回复    2018-06-28 08:32:29 +08:00
    suyuanhxx
        1
    suyuanhxx  
       2018-06-27 17:44:07 +08:00
    肯定会的,eureka 这是还没有将 down 掉的服务剔除掉,还会继续发请求,可以通过设置 ping 时间来减少高可用时间
    sakudie
        2
    sakudie  
    OP
       2018-06-28 08:32:29 +08:00
    @suyuanhxx 这个时候的负载均衡是怎么做的呢?程序运行显示,消费者调用几次失败后,就不再继续尝试了
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   3012 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 26ms · UTC 15:04 · PVG 23:04 · LAX 08:04 · JFK 11:04
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.