客户端如何通过 SpringCloud Gateway + 注册中心(Eureka) 路由到微服务

背景

近期注册中心(Eureka)所在节点发生了一次故障,导致作为Eureka客户端的Gateway不断报错,但是通过Gateway访问微服务并没有受到影响。事后,在测试环境中模拟注册中心服务出现故障(通过关闭注册中心服务)的场景,虽然Gateway本身一直在报错(无法连接注册中心),但是的确没有影响到TA将访问路由到正确的微服务上。通过这次验证,对“客户端如何通过 SpringCloud Gateway + 注册中心(Eureka) 路由到微服务”这个问题重新进行了梳理。

梳理

我们还是来看一张图
客户端如何通过 SpringCloud Gateway + 注册中心(Eureka) 路由到微服务
从上图总结出以下几点问题:

  1. 微服务(ms1、ms2、ms3 … msN)将自己注册到注册中心上
  2. Gateway从注册中心拉取微服务的信息,并且缓存到本地(可通过配置定期同步注册中心上的微服务信息)
  3. 客户端通过Gateway访问微服务(例如:ms2),Gateway通过本地缓存的微服务信息找到ms2对应的地址列表,同时根据一定规则从地址列表中选择一个地址(例如:192.168.0.102)进行路由

综上所述,我们知道Gateway是通过本地缓存的注册信息来进行路由的,所以,在注册中心发生异常,但微服务节点无变化的情况下,并不会影响客户端通过Gateway正常的访问微服务