Eureka 客户端会和在同一个可用区(Zone)的服务端进行通讯,如果通讯失败或者服务端没有和客户端在一个可用区,则客户端将进行失效转移:对其他可用区的服务端发起通讯。 服务端接收到客户端信息后,会进行一些列[链接]将信息同步给其他服务端节点。如果某步操作失败,信息将在下一次心跳时同步给其他服务端节点。 当一个 Eu ..

理解 Eureka 的 P2P 通讯

本贴最后更新于 782 天前,其中的信息可能已经时移俗易

Eureka 客户端会和在同一个可用区(Zone)的服务端进行通讯,如果通讯失败或者服务端没有和客户端在一个可用区,则客户端将进行失效转移:对其他可用区的服务端发起通讯。

服务端接收到客户端信息后,会进行一些列操作将信息同步给其他服务端节点。如果某步操作失败,信息将在下一次心跳时同步给其他服务端节点。

当一个 Eureka 服务端节点启动后,它将向其他服务端节点获取所有实例的注册信息。服务端获取到实例列表后将根据信息创建续约(renew)相关数据并准备接收来自客户端的续约请求。如果在某个时刻客户端续约失败(15 分钟内低于 85%),服务端将停止实例过期防止该实例注册信息丢失。

在 Netflix 内部,上述过程称作自我保护模式,是 Eureka 客户端和服务端通讯时发生断网的一个保护机制。在这个场景下,服务端将尝试保存住已有的注册信息。此时客户端获取的实例列表中有可能有的实例已经不能正常服务了,客户端需要自己保证 Eureka 服务端返回的实例在不存在或不响应情况下是弹性的,最好的处理方式就是对该实例的调用设置较短超时并尝试其他服务器。

当服务端没法从其他节点获取注册信息时,它将等待 5 分钟让客户端注册自己。服务端会尽可能地提供完整信息给客户端,所以可能会导致调用流量集中在某些实例上。

Eureka 服务端 - 服务端之间的通讯也使用客户端 - 服务端通讯同样的机制,参数调整可参考 configurations

服务端节点之间断网会发生什么?

最后需要强调的是,在断网期间,服务端会尽可能保持可用,但不同的客户端可能会看到不同的数据。

译自:Understanding Eureka Peer to Peer Communication

  • Eureka
    12 引用 • 2 回帖
  • 微服务

    微服务架构是一种架构模式,它提倡将单一应用划分成一组小的服务。服务之间互相协调,互相配合,为用户提供最终价值。每个服务运行在独立的进程中。服务于服务之间才用轻量级的通信机制互相沟通。每个服务都围绕着具体业务构建,能够被独立的部署。

    36 引用 • 80 回帖 • 149 关注
  • 客户端
    4 引用 • 87 回帖
1 回帖   
请输入回帖内容...