客户端如何通过 SpringCloud Gateway + 注册中心(Eureka) 路由到微服务
背景
近期注册中心(Eureka)所在节点发生了一次故障,导致作为Eureka客户端的Gateway不断报错,但是通过Gateway访问微服务并没有受到影响。事后,在测试环境中模拟注册中心服务出现故障(通过关闭注册中心服务)的场景,虽然Gateway本身一直在报错(无法连接注册中心),但是的确没有影响到TA将访问路由到正确的微服务上。通过这次验证,对“客户端如何通过 SpringCloud Gateway + 注册中心(Eureka) 路由到微服务”这个问题重新进行了梳理。
梳理
我们还是来看一张图
从上图总结出以下几点问题:
- 微服务(ms1、ms2、ms3 … msN)将自己注册到注册中心上
- Gateway从注册中心拉取微服务的信息,并且缓存到本地(可通过配置定期同步注册中心上的微服务信息)
- 客户端通过Gateway访问微服务(例如:ms2),Gateway通过本地缓存的微服务信息找到ms2对应的地址列表,同时根据一定规则从地址列表中选择一个地址(例如:192.168.0.102)进行路由
综上所述,我们知道Gateway是通过本地缓存的注册信息来进行路由的,所以,在注册中心发生异常,但微服务节点无变化的情况下,并不会影响客户端通过Gateway正常的访问微服务