Spring Cloud Gateway网关Gateway应用实践

x33g5p2x  于2021-09-22 转载在 其他  
字(3.2k)|赞(0)|评价(0)|浏览(343)

一.网关简介

1.背景分析

我们知道,一个大型系统在设计时,经常会被拆分为很多个微服务。那么作为客户端要如何去调用 这么多的微服务呢?客户端可以直接向微服务发送请求,每个微服务都有一个公开的URL,该URL可以直接映射到具体的微服务,如果没有网关的存在,我们只能在客户端记录每个微服务的地址,然后分别去调用。这样的架构,会存在着诸多的问题,例如,客户端请求不同的微服务可能会增加客户端代码或配置的复杂性。还有就是每个服务,在调用时都需要独立认证。并且存在跨域请求,也在一定程度上提高了代码的复杂度。基于微服务架构中的设计及实现上的问题,为了在项目中简化前端的调用逻辑,同时也简化内部服务之间互相调用的复杂度,更好保护内部服务,提出了网关的概念。

2.网关概述

网关本质上要提供一个各种服务访问的入口,并提供服务接收并转发所有内外部的客户端调用,还有就是权限认证,限流控制等等。Spring Cloud Gateway是Spring公司基于Spring 5.0,Spring Boot 2.0 和 等技术开发的一个网关组件,它旨在为微服务架构提供一种简单有效的统一的 API入口,负责服务请求路由、组合及协议转换,并且基于 Filter 链的方式提供了权限认证,监控、限流等功能。

Spring Cloud Gateway优缺点分析:
  • 优点:

1.性能强劲:是第一代网关Zuul的1.6倍。
2.功能强大:内置了很多实用的功能,例如转发、监控、限流等
3.设计优雅,容易扩展。

  • 缺点:
    1.依赖Netty与WebFlux(Spring5.0),不是传统的Servlet编程模型(Spring MVC就是基于此模型实现),学习成本高。
    2.需要Spring Boot 2.0及以上的版本,才支持

3.快速入门

业务描述

通过网关作为服务访问入口,对系统中的服务进行访问,例如通过网关服务去访问sca-provider服务.

入门业务实现

第一步:创建sca-gateway模块,其pom.xml文件如下:

<dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-gateway</artifactId>
        </dependency>
    </dependencies>

第二步:添加相关配置,代码如下:

server:
  port: 9000
#服务名的定义(根据服务需要注册到注册中心,则必须写上服务名)
spring:
  application:
    name: sca-gateway
  cloud:
    gateway: #微服务中的网关配置(api管理--路由的转发,跨域,限流,认证,……)
      routes: #网关路由的定义(后续可以定义多个路由,唯一标识是id)
        - id: router01 #这个名字自己定义具备唯一性即可
          uri: http://localhost:8081/ #定义请求转发的uri
          predicates: #请求逻辑设计,这里又叫谓词,http://localhost:9000/sca/provider/echo/sca
            - Path=/sca/provider/echo/** filters: #过滤器规则定义,当predicates返回值为true,则执行filter - StripPrefix=1 #StripPrefix表示去掉访问路径path中的第一层目录

其中:路由(Route) 是 gateway 中最基本的组件之一,表示一个具体的路由信息载体。主要定义了下面的几个信息:

id,路由标识符,区别于其他 Route。
uri,路由指向的目的地 uri,即客户端请求最终被转发到的微服务。
predicate,断言(谓词)的作用是进行条件判断,只有断言都返回真,才会执行路由。
filter,过滤器用于修改请求和响应信息。

第三步:创建启动类,例如:

package cm.cy;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class GatewayApplication {
    public static void main(String[] args) {
        SpringApplication.run(GatewayApplication.class, args);
    }
}

第四步:启动项目进行访问测试,

依次启动sca-provider,sca-gateway服务,然后打开浏览器,进行访问测试,例如:

小节面试分析?

什么是网关?服务访问(流量)的一个入口,类似生活中的“海关“
为什么使用网关?(服务安全,统一服务入口管理,负载均衡,限流,鉴权)
Spring Cloud Gateway 应用的初始构建过程(添加依赖,配置)
Gateway 服务的启动底层是通过谁去实现的?(Netty网络编程框架-ServerSocket)
Gateway 服务做请求转发时一定要在注册中心进行注册吗?(不一定,可以直接通过远端url进行服务访问)

负载均衡设计

为什么负载均衡?

网关才是服务访问的入口,所有服务都会在网关层面进行底层映射,所以在访问服务时,要基于服务serivce id(服务名)去查找对应的服务,让请求从网关层进行均衡转发,以平衡服务实例的处理能力。

Gateway中负载均衡实现?

第一步:项目中添加服务发现依赖,代码如下:

<dependency>
  <groupId>com.alibaba.cloud</groupId>
  <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>

第二步:修改其配置文件,代码如下

server:
  port: 9000
#服务名的定义(根据服务需要注册到注册中心,则必须写上服务名)
spring:
  application:
    name: sca-gateway
  cloud:
    gateway: #微服务中的网关配置(api管理--路由的转发,跨域,限流,认证,……)
      routes: #网关路由的定义(后续可以定义多个路由,唯一标识是id)
        - id: router01 #这个名字自己定义具备唯一性即可
          #uri: http://localhost:8081/ #定义请求转发的uri
          uri: lb://sca-provider # lb为服务前缀,不能随意写
          predicates: #请求逻辑设计,这里又叫谓词,http://localhost:9000/nacos/provider/echo/sca
            - Path=/nacos/provider/echo/** filters: #过滤器规则定义,当predicates返回值为true,则执行filter - StripPrefix=1 #StripPrefix表示去掉访问路径path中的第一层目录

其中,lb指的是从nacos中按照名称获取微服务,并遵循负载均衡策略。同时建议开发阶段打开gateway日志,代码如下:

spring:
  application:
	gateway: #微服务中的网关配置(api管理--路由的转发,跨域,限流,认证,……)
      discovery:
        locator:
          enabled: true #

第三步:启动服务,进行访问测试,并反复刷新分析,如图所示:

相关文章