step04day06网关分析Gateway实践运用

目录

1.Gateway简介及应用场景

1.1 背景分析

1.2 网关概述 -- Gateway

2.Gateway快速入门

2.1业务描述

 2.2入门业务实现

2.3 负载均衡设计

 2.3.1.为什么负载均衡?

 2.3.2.Gateway中负载均衡实现?

2.4 小节面试分析

3.断言(Predicate)分析

3.1网关调用分析图

​3.2 Predicate 内置工厂

3.2.1.基于Datetime类型的断言工厂

3.2.2.基于header的断言工厂HeaderRoutePredicateFactory

3.2.3.基于Method请求方法的断言工厂

3.2.4.基于Query请求参数的断言工厂,QueryRoutePredicateFactory 

 3.3 Predicate 应用案例实践

3.4 小节面试分析

4.过滤器(Filter)增强 

4.1 概述

4.2 局部过滤器设计及实现

4.3  全局过滤器设计及实现

4.3.1概述

4.3.2 内部代码实现

4.3.3 细节简析及相关知识

4.4 小节面试分析


1.Gateway简介及应用场景

1.1 背景分析

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

1.2 网关概述 -- Gateway

网关本质上要提供一个各种服务访问的入口,并提供服务接收并转发所有内外部的客户端调用,还有就是权限认证,限流控制等等。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及以上的版本,才支持

2.Gateway快速入门

2.1业务描述

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

网关作用:处理用户请求的一个入口

 2.2入门业务实现

1.创建sca-gateway模块,配置pom.xml文件

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

2 添加相关配置

server:
  port: 9000
spring:
  application:
    name: sca-gateway
  cloud:
    gateway:
        routes: #配置网关路由规则
          - id: route01  #路由id,自己指定一个唯一值即可
            uri: http://localhost:8081/ #网关帮我们转发的url
            predicates: ###断言(谓此):匹配请求规则
              - Path=/nacos/provider/echo/**  #请求路径定义,此路径对应uri中的资源
            filters: ##网关过滤器,用于对谓词中的内容进行判断分析以及处理
              - StripPrefix=1 #转发之前去掉path中第一层路径,例如nacos

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

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

3 创建启动类

package com.cy.jt;

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

4.启动项目访问测试

2.3 负载均衡设计

 2.3.1.为什么负载均衡?

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

 2.3.2.Gateway中负载均衡实现?

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

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

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

 routes:
        - id: route01
          ##uri: http://localhost:8081/
          uri: lb://sca-provider # lb为服务前缀,不能随意写
          predicates: ###匹配规则
              - Path=/nacos/provider/echo/**
          filters:
              - StripPrefix=1 #转发之前去掉path中第一层路径,例如nacos

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

2.4 小节面试分析

什么是网关?服务访问(流量)的一个入口,类似生活中的“海关“


为什么使用网关?(服务安全,统一服务入口管理,负载均衡,限流,鉴权)


Spring Cloud Gateway 应用的初始构建过程(添加依赖,配置)


Gateway 服务的启动底层是通过谁去实现的?(Netty网络编程框架-ServerSocket)


Gateway 服务做请求转发时一定要在注册中心进行注册吗?(不一定,可以直接通过远端url进行服务访问)

网关层面是如何实现负载均衡的?(通过服务名去查找具体的服务实例)


网关层面是如何通过服务名查找服务实例的?(Ribbon)


你了解Ribbon中的哪些负载均衡算法?(轮询,权重,hash,……可通过IRule接口进行查看分析)


网关进行请求转发的流程是怎样,有哪些关键对象?(XxxHandlerMapping,Handler,。。。)


网关层面服务的映射方式怎样的?(谓词-path,…,服务名/服务实例)


网关层如何记录服务的映射?(通过map,并要考虑读写锁的应用)

3.断言(Predicate)分析

3.1网关调用分析图

3.2 Predicate 内置工厂

SpringCloud Gateway包括一些内置的断言工厂,所有这些断言都与http请求的不同属性相匹配,具体如下:

3.2.1.基于Datetime类型的断言工厂

此类型的断言根据时间做判断,主要有三个:

1) AfterRoutePredicateFactory:判断请求日期是否晚于指定日期
2) BeforeRoutePredicateFactory:判断请求日期是否早于指定日期
3) BetweenRoutePredicateFactory:判断请求日期是否在指定时间段内

-After=2020-12-31T23:59:59.789+08:00[Asia/Shanghai]

当且仅当请求时的时间After配置的时间时,才转发该请求,若请求时的时间不是After配置的时间时,则会返回404 not found。时间值可通过ZonedDateTime.now()获取。

3.2.2.基于header的断言工厂HeaderRoutePredicateFactory

判断请求Header是否具有给定名称且值与正则表达式匹配。例如:

-Header=X-Request-Id, \d+

3.2.3.基于Method请求方法的断言工厂

MethodRoutePredicateFactory接收一个参数,判断请求类型是否跟指定的类型匹配。例如:

-Method=GET

3.2.4.基于Query请求参数的断言工厂,QueryRoutePredicateFactory 

接收两个参数,请求param和正则表达式, 判断请求参数是否具 有给定名称且值与正则表达式匹配。例如:

-Query=pageSize,\d+

 3.3 Predicate 应用案例实践

server:
  port: 9000
spring:
  application:
    name: sca-gateway
  cloud:
    nacos:
      server-addr: localhost:8848
    gateway:
      discovery:
        locator:
          enabled: true #开启通过服务中心的serviceId 创建路由的功能
      routes:
        - id: bd-id
          ##uri: http://localhost:8081/
          uri: lb://sca-provider
          predicates: ###匹配规则
              - Path=/nacos/provider/echo/**
              - Before=2021-01-30T00:00:00.000+08:00
              - Method=GET
          filters:
            -  StripPrefix=1 # 转发之前去掉1层路径

说明:当条件不满足时,则无法进行路由转发,会出现404异常。

3.4 小节面试分析

何为谓词?(网关中封装了判断逻辑的一个对象)


谓词逻辑的设计是怎样的?(谓词判断逻辑返回值为true则进行请求转发)


你了解哪些谓词逻辑?(path,请求参数,ip,请求方式,cookie,请求头,….)


我们可以自己定义谓词工厂对象吗?(可以的)
 

4.过滤器(Filter)增强 

4.1 概述

过滤器(Filter)就是在请求传递过程中,对请求和响应做一个处理。Gateway 的Filter从作用范围可分为两种:GatewayFilter与GlobalFilter。其中:

  • GatewayFilter:应用到单个路由或者一个分组的路由上。
  • GlobalFilter:应用到所有的路由上。——全局路由

4.2 局部过滤器设计及实现

在SpringCloud Gateway中内置了很多不同类型的网关路由过滤器。具体如下:

基于AddRequestHeaderGatewayFilterFactory,为原始请求添加Header。

 filters:
            - AddRequestHeader=X-Request-Foo, Bar

基于AddRequestParameterGatewayFilterFactory,为原始请求添加请求参数及值。

filters:
            - AddRequestParameter=foo, bar

基于PrefixPathGatewayFilterFactory,为原始的请求路径添加一个前缀路径

  filters:
            - PrefixPath=/mypath

基于RequestSizeGatewayFilterFactory,设置允许接收最大请求包的大小

predicates:
        - Path=/upload
      filters:
        - name: RequestSize
          args:
            # 单位为字节
            maxSize: 5000000

如果请求包大小超过设置的值,则会返回 413 Payload Too Large以及一个errorMessage

4.3  全局过滤器设计及实现

4.3.1概述

全局过滤器(GlobalFilter)作用于所有路由, 无需配置。在系统初始化时加载,并作用在每个路由上。通过全局过滤器可以实现对权限的统一校验,安全性验证等功能。一般内置的全局过滤器已经可以完成大部分的功能,但是对于企业开发的一些业务功能处理,还是需要我们 自己编写过滤器来实现的,那么我们一起通过代码的形式自定义一个过滤器,去完成统一的权限校验。 例如,当客户端第一次请求服务时,服务端对用户进行信息认证(登录) 认证通过,将用户信息进行加密形成token,返回给客户端,作为登录凭证 以后每次请求,客户端都携带认证的token 服务端对token进行解密,判断是否有效。

4.3.2 内部代码实现

@Component
public class AuthGlobalFilter implements GlobalFilter, Ordered {
    @Override
    public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
        String username=exchange.getRequest()
                .getQueryParams().getFirst("username");
        if (!"admin".equals(username)) {
            System.out.println("认证失败");
            exchange.getResponse().setStatusCode(HttpStatus.UNAUTHORIZED);
            return exchange.getResponse().setComplete();
        }
        //调用chain.filter继续向下游执行
        return chain.filter(exchange);

    }

    @Override
    public int getOrder() {
        return 0;
    }
}

4.3.3 细节简析及相关知识

说明:内部判断条件

//获取响应对象
            ServerHttpResponse response=exchange.getResponse();
            //设置响应状态码,这里的值为407
            response.setStatusCode(HttpStatus.UNAUTHORIZED);
            //结束当前的请求
            //return  response.setComplete();

1.方案1--Mono类

DataBuffer dataBuffer=response.bufferFactory().wrap(bytes);
            return response.writeWith(Mono.just(dataBuffer));

2.方案2

//String content="request failure";//第二种方法案
            Map<String ,Object> map=new HashMap<>();
            map.put("message","request failure");
            map.put("status", "502");

            //String jsonStr="{\"message\":\"request failure\",\"status\":502}";
            Gson gson=new Gson();
            String jsonStr=gson.toJson(map);//将map对象转换json格式字符串.
            byte[] bytes=jsonStr.getBytes();

4.4 小节面试分析

网关过滤器的作用是什么?(对请求和响应数据做一个预处理)


网关过滤器的类型有哪些?(局部过滤器,全局过滤器)


如何理解局部过滤器?(针对具体链路的应用的过滤器,需要进行配置)


你了解哪些局部过滤器?


如何理解全局过滤器?(作用于所有请求链路)


如何自己定义全局过滤器?(直接或间接实现GlobalFilter接口)


假如现在让你进行平台的网关自研设计,你可以吗?(可以)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值