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

2018-06-27 16:08:40 +08:00
 sakudie

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

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

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

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

4556 次点击
所在节点    程序员
2 条回复
suyuanhxx
2018-06-27 17:44:07 +08:00
肯定会的,eureka 这是还没有将 down 掉的服务剔除掉,还会继续发请求,可以通过设置 ping 时间来减少高可用时间
sakudie
2018-06-28 08:32:29 +08:00
@suyuanhxx 这个时候的负载均衡是怎么做的呢?程序运行显示,消费者调用几次失败后,就不再继续尝试了

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/466308

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX