首页 > 编程语言 > 详细

SpringCloud Gateway

时间:2021-06-02 15:12:33      阅读:32      评论:0      收藏:0      [点我收藏+]

1.SpringCloud Gateway 简介

SpringCloud Gateway 是 Spring Cloud 的一个全新项目,该项目是基于 Spring 5.0,Spring Boot 2.0 和 Project Reactor 等技术开发的网关,它旨在为微服务架构提供一种简单有效的统一的 API 路由管理方式。

SpringCloud Gateway 作为 Spring Cloud 生态系统中的网关,目标是替代 Zuul,在Spring Cloud 2.0以上版本中,没有对新版本的Zuul 2.0以上最新高性能版本进行集成,仍然还是使用的Zuul 2.0之前的非Reactor模式的老版本。而为了提升网关的性能,SpringCloud Gateway是基于WebFlux框架实现的,而WebFlux框架底层则使用了高性能的Reactor模式通信框架Netty。

Spring Cloud Gateway 的目标,不仅提供统一的路由方式,并且基于 Filter 链的方式提供了网关基本的功能,例如:安全,监控/指标,和限流。

提前声明:Spring Cloud Gateway 底层使用了高性能的通信框架Netty

1.2 SpringCloud Gateway 特征

SpringCloud官方,对SpringCloud Gateway 特征介绍如下:

(1)基于 Spring Framework 5,Project Reactor 和 Spring Boot 2.0

(2)集成 Hystrix 断路器

(3)集成 Spring Cloud DiscoveryClient

(4)Predicates 和 Filters 作用于特定路由,易于编写的 Predicates 和 Filters

(5)具备一些网关的高级功能:动态路由、限流、路径重写

从以上的特征来说,和Zuul的特征差别不大。SpringCloud Gateway和Zuul主要的区别,还是在底层的通信框架上。

简单说明一下上文中的三个术语:

1Filter(过滤器)

和Zuul的过滤器在概念上类似,可以使用它拦截和修改请求,并且对上游的响应,进行二次处理。过滤器为org.springframework.cloud.gateway.filter.GatewayFilter类的实例。

(2)Route(路由):

网关配置的基本组成模块,和Zuul的路由配置模块类似。一个Route模块由一个 ID,一个目标 URI,一组断言和一组过滤器定义。如果断言为真,则路由匹配,目标URI会被访问。

3Predicate(断言)

这是一个 Java 8 的 Predicate,可以使用它来匹配来自 HTTP 请求的任何内容,例如 headers 或参数。断言的输入类型是一个 ServerWebExchange。

2.什么是服务网关

技术分享图片

 

 

3.SpringCloud Gateway怎么用

   3.1 引入依赖(这里springboot版本2.2.8.RELEASE,springboot不能引入web(tomcat)组件

    <properties>
        <java.version>1.8</java.version>
        <spring-cloud.version>Hoxton.SR8</spring-cloud.version>
        <spring-cloud-alibaba.version>2.2.1.RELEASE</spring-cloud-alibaba.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-gateway</artifactId>
        </dependency>
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>
    </dependencies>
    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring-cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
            <dependency>
                <groupId>com.alibaba.cloud</groupId>
                <artifactId>spring-cloud-alibaba-dependencies</artifactId>
                <version>${spring-cloud-alibaba.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

3.2 YML配置

server:
  port: 7001

spring:
  application:
    name: gateway-server
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848
        namespace: e8c32ac0-391b-44dd-94bf-bd23ebaf5aca
    gateway:
      routes:
        - id: member
          uri: http://localhost:9005/
          predicates:
            - Path=/member/**

4.SpringCloud Gateway路由规则

4.1 Path

    gateway:
      routes:
        - id: member
          uri: http://localhost:9005/
          predicates:
            - Path=/member/**

4.2  Query

技术分享图片

 

 4.3 Method

技术分享图片

 

 4.4 DateTime

技术分享图片

 

 4.5 RemoteAddr

技术分享图片

 

4.6 Header

技术分享图片

 

5.SpringCloud Gateway动态路由(服务发现的路由--和注册中心搭配用)

5.1 动态获取URI

    gateway:
      routes:
        - id: member
          uri: lb://member    #lb代表负载均衡   member为注册中心上的服务名
          predicates:
            - Path=/member/**

5.2 服务名称转发

gateway:
      discovery:
        locator:
          enabled: true
          lower-case-service-id: true

这样访问:http://localhost:7001/oneserver-service/oneserver/get/demo     oneserver-service为服务在注册中心上的服务名

技术分享图片

 

 

 

6.SpringCloud Gateway  过滤器

  6.1 网关过滤器

技术分享图片

 

 

  6.2 全局过滤器

技术分享图片

 

 6.2.1 自定义全局过滤器

技术分享图片

 6.2.2 创建全局顾虑器

 技术分享图片

 

SpringCloud Gateway

原文:https://www.cnblogs.com/wiliamzhao/p/14840212.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!