服务注册和发现的基本流程是怎样的?(面试版)

注册中心原理

三个角色

服务治理中的三个角色分别是:

服务提供者:提供接口供其它微服务访问

服务调用者:调用其它微服务提供的接口

注册中心:管理服务

三者的关系

注册中心、服务提供者、服务消费者三者间关系如下:

服务注册和发现的基本流程是怎样的?(面试版)_第1张图片

流程如下:

1、服务启动时,会注册自己的服务信息(服务名、IP、端口)到注册中心

2、调用者可以从注册中心订阅想要的服务,获取服务对应的实例列表(1个服务可能多实例部署),对实例列表负载均衡,挑选一个实例

  • 当提供者有多个实例时,消费者该选择哪一个:使用负载均衡的算法(随机,轮询),从多个实例从选择一个

4、最后, 调用者向该实例发起远程调用

当服务提供者的实例宕机或者启动新实例时,调用者如何得知呢?

  • 服务提供者定期向注册中心发送心跳请求(报告自己的健康状态),当注册中心长时间收不到提供者的心跳时,会认为该实例宕机,将其从服务的实例列表中剔除
  • 当服务有新实例启动时,会发送注册服务的请求,其信息会被记录在注册中心的服务实例列表
  • 当注册中心服务列表变更时,会主动通知微服务,更新本地服务列表

你可能感兴趣的:(SpringCloud,java,开发语言)