简介
服务网关是系统对外的唯一入口,它封装了系统内部架构,为每个客户端提供了定制的API,所有的客户端和消费端都通过统一的网关接入微服务,在网关层处理所有非业务功能。
为什么要使用服务网关?
- 单体应用
浏览器发起请求到单体应用所在的机器,应用从数据库查询数据原路返回给浏览器,对单体应用来说是可以不用网关的。
- 微服务
微服务的应用可能是部署在不同机房、不同地区、不同域名下的。此时客户端想要请求对应的服务,都需要知道机器的具体IP或域名;当微服务实例众多时,对客户端来说就难以维护。此时就有了网关,客户端相关的请求直接发送到网关,由网关根据请求标识解析判断出具体的微服务网址,再把请求发送到服务实例上。
如果由客户端直接请求各个微服务,会存在以下问题:
-
客户端多次请求不同的微服务,增加了网络的负担和客户端的复杂性
-
身份认证问题,每个微服务都需要独立身份认证
-
难以重构,随着项目的迭代,可能需要重新规划微服务
-
存在跨域请求,每个服务都要处理,非常麻烦
因此,我们需要网关介于客户端和服务端之间的中间层,所有外部请求率先经过网关,客户端只需要与网关交