百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

微服务入门-Spring Cloud Gateway路由配置详解?

ztj100 2024-10-29 18:19 17 浏览 0 评论

在之前的分享中,我们介绍了Spring Cloud Gateway微服务网关技术,并且知道了Spring Cloud Gateway提供了很多灵活的方式来配置和管理路由请求、过滤请求、转换协议等。下面我们就来看看Spring Cloud Gateway如何实现路由配置的。

路由搜索引擎

搭建Spring Boot项目,并且引入Gateway相关的依赖,如下所示。

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

添加路由百度的的配置路由配置,如下所示。

server:
  port: 4000
# application.yml
spring:
  cloud:
    gateway:
      routes:
        - id: example_route
          uri: https://www.baidu.com
          predicates:
            - Path=/**

这个时候,我们启动项目之后就访问http://localhost:4000/就可以看到如下的效果了。

居然在本地localhost上访问的到了搜索引擎的的首页,这个是个什么原理?下面我们就来一起探索一下Spring Cloud Gateway路由配置相关的内容吧?

Gateway路由配置介绍

如下所示,是我们在上面的例子中提供的一个简单的路由配置规则。

spring:
  cloud:
    gateway:
      routes:
        - id: example_route
          uri: https://www.baidu.com/s
          predicates:
            - Path=/baidu/**
          filters:
            - RewritePath=/baidu/(?<segment>.*), /s?wd=$\{segment}
  • ID(id):因为在配置中,每个路由规则都需要一个唯一的标识符来区分。而这个ID通常就是用于标识路由规则,这样可以方便在后续的管理和调试中使用。
  • URI(uri):这个配置,指定了路由规则的目标 URI,即请求将被转发到的目标服务的地址,如上面的我们将请求转发到了搜索引擎首页
  • 谓词(predicates):用于匹配请求的条件,以决定是否应该应用该路由规则。Spring Cloud Gateway 提供了多种预定义的谓词,如 Path、Method、Header 等,可以根据请求的路径、方法、请求头等条件来进行匹配。
  • 过滤器(filters):用于对请求进行处理和转换的组件。过滤器可以用于添加请求头、修改请求和响应、进行路由重写、记录日志等。Spring Cloud Gateway 提供了多种预定义的过滤器,也支持自定义过滤器。
  • 其他属性:除了上述属性之外,还可以在路由规则中定义其他属性,如断路器配置、负载均衡配置等

Spring Cloud Gateway提供的路由配置中允许我们可以根据具体的需求来定义一个或者多个路由匹配的规则,来控制请求的转发和处理。我们可以通过请求的路径、方法、请求头等条件来匹配路由规则,并通过过滤器对请求进行处理和转换,如上所示,展示了通过路径排进行匹配,并且通过过滤实现了关键字搜索的功能。下面我们就来详细介绍一下这些匹配规则。

通过请求头规则进行路由配置?

上面我们提到再配置路由规则的时候,可以通过路径的方式来进行配置,就如上面的例子中展示的那个样子,我们也可以通过配置请求头的规则来实现路由的配置,如下所示。

spring:
  cloud:
    gateway:
      routes:
        - id: example_route
          uri: http://example.com
          predicates:
            - Header=X-Custom-Header, value

在这个配置中,我们使用了Header这个谓词逻辑来匹配请求的头部信息。通过定义X-Custom-Header 来表示是请求头的名称,而value是匹配的值。这也就意味着只有当请求头中包含 X-Custom-Header: value 这样的内容时,才会匹配到这个路由规则,将请求转发到 http://example.com。

当然在上面的配置中,X-Custom-Header: value 中的 value 可以是具体的值,这个值用于匹配请求头中的实际内容。当请求头中的值与配置中指定的值完全相同时,才会匹配成功。如下所示。

spring:
  cloud:
    gateway:
      routes:
        - id: example_route
          uri: http://example.com
          predicates:
            - Header=X-Custom-Header, example

在这个配置规则中,请求头中的X-Custom-Header的值是example,那么只有当路由配置中的值也是 example 时,才会匹配成功。这意味着请求头的值必须与路由配置中指定的值一致,才能触发路由规则。

当然我们也可以通过逻辑运算符来组合请求头中所包含的条件,例如and、or等。如下所示。

spring:
  cloud:
    gateway:
      routes:
        - id: example_route
          uri: http://example.com
          predicates:
            - Header=X-Custom-Header, value
            - Or:
              - Header=X-Another-Header, anotherValue
              - Header=X-Yet-Another-Header, yetAnotherValue

在这个示例中,我们使用了Or这个逻辑运算符来组合路由匹配的条件。也就是说,如果请求头中的X-Custom-Header的值是value,或者请求头中的 X-Another-Header 的值是 anotherValue,或者请求头中的 X-Yet-Another-Header 的值是 yetAnotherValue,都会触发路由规则,将请求转发到 http://example.com。

通过请求方法来匹配路由?

在HTTP中我们有四种常见的请求方式,分别是GET、POST、PUT、DELETE 等,而在Spring Cloud Gateway中就提供了通过请求方法来匹配路由规则的方式。如下所示。

spring:
  cloud:
    gateway:
      routes:
        - id: example_route
          uri: http://example.com
          predicates:
            - Method=GET

在这个配置中,我们使用了 Method 谓词来匹配请求的方法。这个路由规则表示只有当请求的方法为GET时,才会触发该路由规则,将请求转发到 http://example.com。当然这种限制,在实际使用的时候并不是太合理,一般情况下,我们也不会这么用。如下所示,才是一个正确的使用方式。

spring:
  cloud:
    gateway:
      routes:
        - id: example_route
          uri: http://example.com
          predicates:
            - Method=GET
            - Path=/api/**

这个配置表示只有当请求的方法为GET的时候,并且请求的路径以 /api/ 开头时,才会触发该路由规则,将请求转发到 http://example.com。

过滤器操作

过滤器是Spring Cloud Gateway中用来对请求和响应进行处理和转换的组件。它可以实现在请求被路由之前(pre)或者之后(post)执行一些逻辑实现一些额外的功能,例如鉴权、日志记录、请求转换、添加头部、修改响应等。

在Spring Cloud Gateway 提供了一些默认的预定义的过滤器,当然同时它也支持自定义过滤器。

默认的预定过滤器

  • AddRequestHeader:向请求中添加一个新的头部。
  • AddResponseHeader:向响应中添加一个新的头部。
  • RewritePath:重写请求的路径。
  • RewriteResponseHeader:重写响应的头部。
  • SetPath:设置请求的路径。
  • SetResponseHeader:设置响应的头部。
  • RemoveRequestHeader:移除请求中的某个头部。
  • RemoveResponseHeader:移除响应中的某个头部。
  • Hystrix:集成断路器模式,用于处理请求时的容错和降级。
  • RateLimiter:限流过滤器,用于控制请求的流量。

如下所示,我们在进行过滤器配置的时候,可以指定一个或者是多个的过滤器属性来对请求进行过滤操作。如下所示。

spring:
  cloud:
    gateway:
      routes:
        - id: example_route
          uri: http://example.com
          predicates:
            - Path=/api/**
          filters:
            - AddRequestHeader=X-Custom-Header, value
            - RewritePath=/api/(?<segment>.*), /$\{segment}

在这个例子中,我们使用了两个过滤器,分别是AddRequestHeader和RewritePath。第一个过滤器用于向请求中添加一个名为X-Custom-Header 的头部,第二个过滤器用于重写请求的路径。这样,当请求匹配到这个路由规则时,会依次执行这两个过滤器对请求进行处理和转换。当然除了使用预设的一些过滤器之外,我们还可以实现自定义的过滤器,如下所示。

自定义过滤器

自定义过滤器可以通过实现 GatewayFilterFactory 接口来实现,在这里我们首先创建了一个名为CustomLoggingGatewayFilterFactory的日志工厂类,并且在这个类中实现GatewayFilterFactory<CustomLoggingGatewayFilterFactory.Config> 接口,如下所示。

import org.springframework.cloud.gateway.filter.GatewayFilter;
import org.springframework.cloud.gateway.filter.factory.GatewayFilterFactory;
import org.springframework.http.server.reactive.ServerHttpRequest;
import org.springframework.stereotype.Component;
import reactor.core.publisher.Mono;

import java.util.Arrays;
import java.util.List;

@Component
public class CustomLoggingGatewayFilterFactory implements GatewayFilterFactory<CustomLoggingGatewayFilterFactory.Config> {

    @Override
    public GatewayFilter apply(Config config) {
        return (exchange, chain) -> {
            // 打印请求的信息
            ServerHttpRequest request = exchange.getRequest();
            System.out.println("Request Method: " + request.getMethod());
            System.out.println("Request URI: " + request.getURI());

            // 继续处理请求链
            return chain.filter(exchange);
        };
    }

    @Override
    public List<String> shortcutFieldOrder() {
        return Arrays.asList();
    }

    public static class Config {
        // 可以定义一些配置参数
    }
}

在这个自定义的过滤器中,通过重写apply方法,简单地打印了请求的方法和URI。然后,我们返回一个GatewayFilter对象,用于对请求进行处理。并且在Config类中,我们可以定义一些配置参数,用于在创建过滤器实例时配置过滤器的行为。在这个示例中,我们没有定义任何配置参数,因此shortcutFieldOrder方法返回了一个空的列表。

在路由规则中配置使用,如下所示。

spring:
  cloud:
    gateway:
      routes:
        - id: custom_logging_route
          uri: http://example.com
          predicates:
            - Path=/api/**
          filters:
            - name: CustomLogging

使用我们自定义的过滤器CustomLogging。最终运行程序会在输出日志中看到我们的请求调用的信息。

总结

上面我们介绍了关于SpringCloud Gateway的路由匹配规则的使用,并且介绍如何自定义过滤操作,根据不同的路由匹配规则可以实现动态的路由配置调整,来满足我们的业务需求。

相关推荐

从IDEA开始,迈进GO语言之门(idea got)

前言笔者在学习GO语言编程的时候,GO语言在国内还没有像JAVA/Php/Python那样普及,绕了不少的弯路,要开始入门学习一门编程语言,最好就先从选择一个好的编程语言的开发环境开始,有了这个开发环...

基于SpringBoot+MyBatis的私人影院java网上购票jsp源代码Mysql

本项目为前几天收费帮学妹做的一个项目,JavaEEJSP项目,在工作环境中基本使用不到,但是很多学校把这个当作编程入门的项目来做,故分享出本项目供初学者参考。一、项目介绍基于SpringBoot...

基于springboot的个人服装管理系统java网上商城jsp源代码mysql

本项目为前几天收费帮学妹做的一个项目,JavaEEJSP项目,在工作环境中基本使用不到,但是很多学校把这个当作编程入门的项目来做,故分享出本项目供初学者参考。一、项目介绍基于springboot...

基于springboot的美食网站Java食品销售jsp源代码Mysql

本项目为前几天收费帮学妹做的一个项目,JavaEEJSP项目,在工作环境中基本使用不到,但是很多学校把这个当作编程入门的项目来做,故分享出本项目供初学者参考。一、项目介绍基于springboot...

贸易管理进销存springboot云管货管账分析java jsp源代码mysql

本项目为前几天收费帮学妹做的一个项目,JavaEEJSP项目,在工作环境中基本使用不到,但是很多学校把这个当作编程入门的项目来做,故分享出本项目供初学者参考。一、项目描述贸易管理进销存spring...

SpringBoot+VUE员工信息管理系统Java人员管理jsp源代码Mysql

本项目为前几天收费帮学妹做的一个项目,JavaEEJSP项目,在工作环境中基本使用不到,但是很多学校把这个当作编程入门的项目来做,故分享出本项目供初学者参考。一、项目介绍SpringBoot+V...

目前见过最牛的一个SpringBoot商城项目(附源码)还有人没用过吗

帮粉丝找了一个基于SpringBoot的天猫商城项目,快速部署运行,所用技术:MySQL,Druid,Log4j2,Maven,Echarts,Bootstrap...免费给大家分享出来前台演示...

SpringBoot+Mysql实现的手机商城附带源码演示导入视频

今天为大家带来的是基于SpringBoot+JPA+Thymeleaf框架的手机商城管理系统,商城系统分为前台和后台、前台用的是Bootstrap框架后台用的是SpringBoot+JPA都是现在主...

全网首发!马士兵内部共享—1658页《Java面试突击核心讲》

又是一年一度的“金九银十”秋招大热门,为助力广大程序员朋友“面试造火箭”,小编今天给大家分享的便是这份马士兵内部的面试神技——1658页《Java面试突击核心讲》!...

SpringBoot数据库操作的应用(springboot与数据库交互)

1.JDBC+HikariDataSource...

SpringBoot 整合 Flink 实时同步 MySQL

1、需求在Flink发布SpringBoot打包的jar包能够实时同步MySQL表,做到原表进行新增、修改、删除的时候目标表都能对应同步。...

SpringBoot + Mybatis + Shiro + mysql + redis智能平台源码分享

后端技术栈基于SpringBoot+Mybatis+Shiro+mysql+redis构建的智慧云智能教育平台基于数据驱动视图的理念封装element-ui,即使没有vue的使...

Springboot+Mysql舞蹈课程在线预约系统源码附带视频运行教程

今天发布的是由【猿来入此】的优秀学员独立做的一个基于springboot脚手架的Springboot+Mysql舞蹈课程在线预约系统,系统项目源代码在【猿来入此】获取!https://www.yuan...

SpringBoot+Mysql在线众筹系统源码+讲解视频+开发文档(参考论文

今天发布的是由【猿来入此】的优秀学员独立做的一个基于springboot脚手架的在线众筹管理系统,主要实现了普通用户在线参与众筹基本操作流程的全部功能,系统分普通用户、超级管理员等角色,除基础脚手架外...

Docker一键部署 SpringBoot 应用的方法,贼快贼好用

这两天发现个Gradle插件,支持一键打包、推送Docker镜像。今天我们来讲讲这个插件,希望对大家有所帮助!GradleDockerPlugin简介...

取消回复欢迎 发表评论: