网关 介绍

网关 介绍

网关介绍

大家都知道在微服务架构中,一个系统会被拆分为很多个微服务。那么作为客户端要如何去调用这么多的微服务呢?
如果没有网关的存在,我们只能在客户端记录每个微服务的地址,然后分别去用。
在这里插入图片描述
这样的架构,会存在着很多的问题:
1》每个业务都会需要鉴权、限流、权限校验、跨域等逻辑,如果每个业务都各自为站,自己造轮子实现一遍,代码会很冗余,完全可以抽出来,放到一个统一的地方去做。
2》如果业务量比较简单的话,这种方式前期不会有什么问题,但随着业务越来越复杂,比如淘宝、亚马逊打开一个页面可能会涉及到数百个微服务协同工作,如果每一个微服务都分配一个域名的话,一方面客户端代码会很难维护,涉及到数百个域名,另一方面是连续数的瓶颈,例如:打开一个APP,通过抓包发现涉及到了数百个远程调用,这在移动端下会显得非常低效。
3》后期如果需要对微服务进行重构的话,也会变的非常麻烦,需要客户端配合你一起进行改造,比如商品服务,随着业务变的越来越复杂,后期需要进行拆分成多个微服务,这个时候对外提供的服务也需要拆分成多个,同时需要客户端配合你进行改造。

上面的这些问题可以借组API网关来解决。
在这里插入图片描述
所谓的API网关,就是指系统的统一入口,它封装了应用程序的内部结构,为客户端提供统一服务,一些与业务本身功能无关的公共逻辑可以在这里实现,诸如认证、鉴权、监控、路由转发等等。
添加上API网关之后,系统的架构图变成了如下所示:
在这里插入图片描述
我们可以观察一下,我们现在的整体架构图:
在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/muriyue6/article/details/121572279
今日推荐