专注于 JetBrains IDEA 全家桶,永久激活,教程
持续更新 PyCharm,IDEA,WebStorm,PhpStorm,DataGrip,RubyMine,CLion,AppCode 永久激活教程

Spring Cloud GateWay 应用 -> 高可用

一、GateWay简介

Spring Cloud GateWay(它只是众多⽹关解决⽅案中的⼀种)。

Spring Cloud GateWay是Spring Cloud的⼀个全新项⽬,⽬标是取代Netflix Zuul,它基于Spring5.0+SpringBoot2.0+WebFlux(基于⾼性能的Reactor模式响应式通信框架Netty,异步⾮阻塞模型)等技术开发,性能⾼于Zuul,官⽅测试,GateWay是Zuul的1.6倍,旨在为微服务架构提供⼀种简单有效的统⼀的API路由管理⽅式。

Spring Cloud GateWay不仅提供统⼀的路由⽅式(反向代理)并且基于Filter(定义过滤器对请求过滤,完成⼀些功能)链的⽅式提供了⽹关基本的功能,例如:鉴权、流量控制、熔断、路径重写、⽇志监控等。

⽹关在架构中的位置:

86_1.png

二、 GateWay核⼼概念

Zuul1.x 阻塞式IO 2.x 基于Netty Spring Cloud GateWay天⽣就是异步⾮阻塞的,基于Reactor模型

⼀个请求—>⽹关根据⼀定的条件匹配—匹配成功之后可以将请求转发到指定的服务地址;⽽在这个过 程中,我们可以进⾏⼀些⽐较具体的控制(限流、⽇志、⿊⽩名单)

  • 路由(route): ⽹关最基础的部分,也是⽹关⽐较基础的⼯作单元。路由由⼀个ID、⼀个⽬标URL(最终路由到的地址)、⼀系列的断⾔(匹配条件判断)和Filter过滤器(精细化控制)组成。如果断⾔为true,则匹配该路由。
  • 断⾔(predicates):参考了Java8中的断⾔java.util.function.Predicate,开发⼈员可以匹配Http请求中的所有内容(包括请求头、请求参数等)(类似于nginx中的location匹配⼀样),如果断⾔与请求相匹配则路由。
  • 过滤器(filter):⼀个标准的Spring webFilter,使⽤过滤器,可以在请求之前或者之后执⾏业务逻辑。

来⾃官⽹的⼀张图

86_2.png

其中,Predicates断⾔就是我们的匹配条件,⽽Filter就可以理解为⼀个⽆所不能的拦截器,有了这两个元素,结合⽬标URL,就可以实现⼀个具体的路由转发。

三、GateWay⼯作过程(How It Works)

86_3.png

Filter在“pre”类型过滤器中可以做参数校验、权限校验、流量监控、⽇志输出、协议转换等,在“post”类 型的过滤器中可以做响应内容、响应头的修改、⽇志的输出、流量监控等。

GateWay核⼼逻辑:路由转发+执⾏过滤器链

四、GateWay应⽤

  • 导⼊依赖,GateWay不需要使⽤web模块,它引⼊的是WebFlux(类似于SpringMVC),注意:不要引⼊starter-web模块,需要引⼊web-flux
  • application.yml 配置⽂件部分内容
server:
  port: 9002
eureka:
  client:
    serviceUrl: # eureka server的路径
      defaultZone: http://127.0.0.1:8761/eureka/,http://127.0.0.1:8762/eureka/ #把 eureka 集群中的所有 url 都填写了进来,也可以只写一台,因为各个 eureka server 可以同步注册表
  instance:
    #使用ip注册,否则会使用主机名注册了(此处考虑到对老版本的兼容,新版本经过实验都是ip)
    prefer-ip-address: true

spring:
  application:
    name: gateway-9002
  cloud:
    # config客户端配置,和ConfigServer通信,并告知ConfigServer希望获取的配置信息在哪个文件中
    config:
      discovery:
        enabled: true
        service-id: config-bus-9006
    gateway:
      routes: # 路由可以有多个
        - id: lagou-service-user # 我们自定义的路由 ID,保持唯一
          uri: lb://lagou-service-user
          predicates:
            - Path=/api/user/**
        - id: lagou-service-code # 我们自定义的路由 ID,保持唯一
          uri: lb://lagou-service-code
          predicates:
            - Path=/api/code/**

五、GateWay路由规则详解

86_4.png

实现动态路由

GateWay⽀持⾃动从注册中⼼中获取服务列表并访问,即所谓的动态路由

  • pom.xml中添加注册中⼼客户端依赖(因为要获取注册中⼼服务列表,eureka客户端已经引⼊)
  • 动态路由配置 86_5.png

注意:动态路由设置时,uri以 lb: //开头(lb代表从注册中⼼获取服务),后⾯是需要转发到的服务名 称

六、GateWay过滤器

  • 从过滤器⽣命周期(影响时机点)的⻆度来说,主要有两个pre和post:

86_6.png

  • 从过滤器类型的⻆度,Spring Cloud GateWay的过滤器分为GateWayFilter和GlobalFilter两种

86_7.png

  • 使用如下:

86_8.png

七、GateWay⾼可⽤

GateWay的⾼可⽤很简单:可以启动多个GateWay实例来实现⾼可⽤,在GateWay的上游使⽤Nginx等负载均衡设备进⾏负载转发以达到⾼可⽤的⽬的。

86_9.png

文章永久链接:https://tech.souyunku.com/29254

未经允许不得转载:搜云库技术团队 » Spring Cloud GateWay 应用 -> 高可用

JetBrains 全家桶,激活、破解、教程

提供 JetBrains 全家桶激活码、注册码、破解补丁下载及详细激活教程,支持 IntelliJ IDEA、PyCharm、WebStorm 等工具的永久激活。无论是破解教程,还是最新激活码,均可免费获得,帮助开发者解决常见激活问题,确保轻松破解并快速使用 JetBrains 软件。获取免费的破解补丁和激活码,快速解决激活难题,全面覆盖 2024/2025 版本!

联系我们联系我们