微服务之网关与注册中心高可用架构设计

Posted 软件老王

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了微服务之网关与注册中心高可用架构设计相关的知识,希望对你有一定的参考价值。

1. 微服务关系架构图

微服务之网关与注册中心高可用架构设计

简要说明:

(1)所有应用或者服务要想对外提供服务(包括网关),必须首先到注册中心进行注册。

(2)所有访问通过服务网关进行访问,然后由服务网关路由到对应服务中心进行交互访问。

2. 网关及注册中心高可用架构图

2.1 springcloud eureka高可用方案

由上图可以看出,注册中心与路由很容易成为单点故障,软件老王以前使用springcloud eureka高可用架构方案:

(1)euraka部署成集群模式,相互注册,通过心跳策略同步注册信息;

 defaultZone: http://10.192.168.12:8761/eureka/,http://10.192.168.13:8761/eureka/

当时网关没有做高可用方案。

2.2 网关高可用架构方案

2.2.1 软件老王采用的技术方案是:采用keepalived+nginx实现网关的高可用,架构图如下:

微服务之网关与注册中心高可用架构设计

简要说明:

(1)通过nginx来实现gateway集群部署;

(2)通过keepalived虚拟ip,当服务器1宕机后,虚拟ip会自动切换到服务器2上,来保证nginx的高可用。

2.2.2 中台实际部署

因服务器资源有限,软件老王目前有3台服务器资源,分别为:10.192.168.11、10.192.168.12、10.192.168.13

微服务之网关与注册中心高可用架构设计

简要说明:

网关统一使用vip(10.192.168.21)进行访问,21默认会路由到10.192.168.11服务器上(11出故障的话,会自动谢欢到12服务器上),11上的nginx默认轮询调用gateway服务(11与12上启动了6个服务),进而实现高可用。

2.3 注册中心高可用方案

2.3.1 技术方案

软件老王经过技术选型后,这次的注册中心选择的是阿里巴巴的nacos,nacos官方已经给了高可用部署方案,nacos与cloud的euraka还有一个区别,客户端不能配置两个注册中心,官方给的架构图是:

微服务之网关与注册中心高可用架构设计

2.3.2 软件老王实际部署的注册中心(nacos)架构图

其中10.192.168.22为vip,案例演示:gateway默认启动了demo服务(/demo),可进行演示使用。


END/往期推荐:




1.

2.

3.

4.

5.

原创不易,如果觉得有点用的话,请毫不留情地素质三连吧,分享、点赞、在看,我不挑,因为这将是我写作更多优质文章的最强动力。

以上是关于微服务之网关与注册中心高可用架构设计的主要内容,如果未能解决你的问题,请参考以下文章

微服务时代之网关及注册中心高可用架构设计

微服务实战系列-注册中心与网关高可用架构设计

Spring Cloud构建微服务架构高可用服务注册中心

技术京东京麦:微服务架构下的高可用网关与容错实践

微服务架构下的高可用网关与容错

微服务高可用之熔断器实现原理与 Golang 实践