7.统一网关-Gateway

news2025/1/10 21:06:10

文章目录

  • 1.统一网关介绍
  • 2.网关开发
  • 3.predicate
  • 4.Route Predicate Factories(路由断言工厂)
    • 4.1Path 路由断言工厂
    • 4.2.Method 路由断言工厂
    • 4.3 Header 路由断言工厂
    • 4.4 Query 路由断言工厂
    • 4.5 Host 路由断言工厂
    • 4.6 After 路由断言工厂
    • 4.7 Before 路由断言工厂
    • 4.8 Between 路由断言工厂
  • 5.Gateway Filter Factories (网关过滤器工厂)
    • 5.1 The AddRequestHeader GatewayFilter Factory
    • 5.2 The AddRequestParameter GatewayFilter Factory
    • 5.3 The AddResponseHeader GatewayFilter Factory
    • 5.4 The DedupeResponseHeader GatewayFilter Factory
    • 5.5 Spring Cloud CircuitBreaker GatewayFilter Factory
    • 5.6 The FallbackHeaders GatewayFilter Factory
    • 5.7 自定义GatewayFilter
  • 6.限流 - 限制流量
  • 7.GlobalFilter
  • 8.服务部署流程

大家好,我是晓星航。今天为大家带来的是 统一网关-Gateway 相关的讲解!😀

1.统一网关介绍

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

QQ_1721899874115

网关核心功能:

1.权限控制

2.动态路由

3.负载均衡

4.限流

2.网关开发

1.创建项目

QQ_1721900359613

2.引入网关相关依赖

QQ_1721900393591

3.写启动类

QQ_1721900434307

4.配置文件

QQ_1721900624328

QQ_1721901178562

server:
  port: 10030
spring:
  application:
    name: gateway
  cloud:
    nacos:
      discovery:
        server-addr: 110.41.51.65:10020
    gateway:
      metrics:
        enabled: true
      routes:
        - id: order-service   #路由规则id, 随便起, 不重复即可
          uri: lb://order-service/ #目标服务地址
          predicates:   #路由条件
            - Path=/order/**,/feign/**
            - After=2024-03-20T00:00:22.370856700+08:00[Asia/Shanghai]
          filters:
            - AddRequestParameter=userName, bite
            - name: Custom    #过滤器名称
              args:
                name: test_custom
        - id: product-service
          uri: lb://product-service/
          predicates:
            - Path=/product/**
      default-filters:
        - name: Retry
          args:
            retries: 3
            statuses: BAD_GATEWAY
management:
  endpoints:
    web:
      exposure:
        include: "*"
#  endpoint:
#    health:
#      show-details: always
#    shutdown:
#      enabled: true

5.测试

QQ_1721900708532

3.predicate

在 Spring Cloud 中,Predicate 是指用于路由断言(Route Predicate)的一种组件。Spring Cloud 中的路由(Routing)功能通常用于服务网关(如 Spring Cloud Gateway 或 Zuul),它允许根据请求的特定条件(例如路径、方法、头部信息等)将请求路由到不同的目标服务。

基础写法:

QQ_1721901496363

匿名内部类:

QQ_1721901517183

lambda表达式:

QQ_1721901544232

negate 非

QQ_1721901571892

or 判断字符串为 aa或者bb

QQ_1721901596073

and 字符串不为空,且由数字组成,比如 “12”, “34”

QQ_1721901626881

4.Route Predicate Factories(路由断言工厂)

QQ_1722148242744

**QQ_1722148276150**

这里便是我们路由断言的作用,例如上面条件为要在2024.03.20日后发送才会有相应的效果

4.1Path 路由断言工厂

根据请求路径匹配路由。

spring:
  cloud:
    gateway:
      routes:
      - id: path_route
        uri: http://httpbin.org
        predicates:
        - Path=/foo/**  # 匹配所有以 /foo/ 开头的请求=

4.2.Method 路由断言工厂

根据 HTTP 请求方法匹配路由。

spring:
  cloud:
    gateway:
      routes:
      - id: method_route
        uri: http://httpbin.org
        predicates:
        - Method=GET  # 匹配所有 GET 请求

4.3 Header 路由断言工厂

根据请求头的值匹配路由

spring:
  cloud:
    gateway:
      routes:
      - id: header_route
        uri: http://httpbin.org
        predicates:
        - Header=X-Request-Id, \d+  # 匹配请求头 X-Request-Id 存在且值为数字的请求

4.4 Query 路由断言工厂

根据查询参数匹配路由

spring:
  cloud:
    gateway:
      routes:
      - id: query_route
        uri: http://httpbin.org
        predicates:
        - QueryParam=foo, bar  # 匹配查询参数 foo 的值为 bar 的请求

4.5 Host 路由断言工厂

根据请求的 Host 头部信息匹配路由

spring:
  cloud:
    gateway:
      routes:
      - id: host_route
        uri: http://httpbin.org
        predicates:
        - Host=**.example.com  # 匹配所有以 example.com 结尾的主机名

4.6 After 路由断言工厂

根据请求时间在指定时间之后匹配路由

spring:
  cloud:
    gateway:
      routes:
      - id: after_route
        uri: http://httpbin.org
        predicates:
        - After=2023-01-20T17:42:47.789-07:00[America/Denver]  # 匹配指定时间之后的请求

4.7 Before 路由断言工厂

根据请求时间在指定时间之前匹配路由

spring:
  cloud:
    gateway:
      routes:
      - id: before_route
        uri: http://httpbin.org
        predicates:
        - Before=2023-01-20T17:42:47.789-07:00[America/Denver]  # 匹配指定时间之前的请求

4.8 Between 路由断言工厂

根据请求时间在两个时间之间匹配路由

spring:
  cloud:
    gateway:
      routes:
      - id: between_route
        uri: http://httpbin.org
        predicates:
        - Between=2023-01-20T17:42:47.789-07:00[America/Denver],2023-01-21T17:42:47.789-07:00[America/Denver]  # 匹配两个时间之间的请求

5.Gateway Filter Factories (网关过滤器工厂)

5.1 The AddRequestHeader GatewayFilter Factory

spring:
  cloud:
    gateway:
      routes:
      - id: add_request_header_route
        uri: https://example.org
        predicates:
        - Path=/red/{segment}
        filters:
        - AddRequestHeader=X-Request-Red, Blue-{segment}

添加头信息:X-Request-Red,value为Blue-{segment},segment是路径里面带的信息

5.2 The AddRequestParameter GatewayFilter Factory

spring:
  cloud:
    gateway:
      routes:
      - id: add_request_parameter_route
        uri: https://example.org
        predicates:
        - Host: {segment}.myhost.org
        filters:
        - AddRequestParameter=foo, bar-{segment}

添加参数name=foo,value=bar-{segment}

5.3 The AddResponseHeader GatewayFilter Factory

spring:
  cloud:
    gateway:
      routes:
      - id: add_response_header_route
        uri: https://example.org
        predicates:
        - Host: {segment}.myhost.org
        filters:
        - AddResponseHeader=foo, bar-{segment}

5.4 The DedupeResponseHeader GatewayFilter Factory

spring:
  cloud:
    gateway:
      routes:
      - id: dedupe_response_header_route
        uri: https://example.org
        filters:
        - DedupeResponseHeader=Access-Control-Allow-Credentials Access-Control-Allow-Origin

当网关CROS和下游响应头都有Access-Control-Allow-Credentials 和 Access-Control-Allow-Origin时,将删除重复的响应头

5.5 Spring Cloud CircuitBreaker GatewayFilter Factory

使⽤ Spring Cloud CircuitBreaker的API将⽹关路由包装到断路器中。Spring Cloud CircuitBreaker ⽀持多种库⽤于Spring Cloud Gateway。⽐如Resilience4J。
要启⽤Spring Cloud CircuitBreaker过滤器,你需要引⼊spring-cloud-starter-circuitbreaker-reactor-resilience4j ,如下是配置示例

spring:
  cloud:
    gateway:
      routes:
      - id: circuitbreaker_route
        uri: lb://backing-service:8088
        predicates:
        - Path=/consumingServiceEndpoint
        filters:
        - name: CircuitBreaker
          args:
            name: myCircuitBreaker
            fallbackUri: forward:/inCaseOfFailureUseThis
        - RewritePath=/consumingServiceEndpoint, /backingServiceEndpoint

5.6 The FallbackHeaders GatewayFilter Factory

spring:
  cloud:
    gateway:
      routes:
      - id: ingredients
        uri: lb://ingredients
        predicates:
        - Path=//ingredients/**
        filters:
        - name: CircuitBreaker
          args:
            name: fetchIngredients
            fallbackUri: forward:/fallback
      - id: ingredients-fallback
        uri: http://localhost:9994
        predicates:
        - Path=/fallback
        filters:
        - name: FallbackHeaders
          args:
            executionExceptionTypeHeaderName: Test-Header

The FallbackHeaders GatewayFilter Factory
在该例中,在运⾏circuit breaker 发生异常后,请求将被转发到 http://localhost:9994 的 /fallback 中。异常类型、消息等通过 FallbackHeaders 过滤器添加到请求头中。

5.7 自定义GatewayFilter

过滤器的代码逻辑:

QQ_1722151572838

QQ_1722151858799

QQ_1722152052530

6.限流 - 限制流量

限流算法

1.固定窗口

QQ_1722149704687

2.滑动窗口

QQ_1722149718611

滑动窗口 也有小问题例如我们应该多久滑动一次呢,是一分钟还是10秒钟呢

3.漏桶算法

QQ_1722149733390

请求类似于生产者

请求处理速度类似消费者

露桶类似于队列

应激流量:突然出现的大量流量。

4.令牌算法

QQ_1722149747868

限流实现

7.GlobalFilter

GlobalFilter是Spring Cloud Gateway中的全局过滤器,它和GatewayFilter的作用是相同的.

GlobalFilter 会应用到所有的路由请求上,全局过滤器通常用于实现与安全性,性能监控和日志记录等相关的全局功能.

SpringCloud Gateway 内置的全局过滤器也有很多,比如:

  • Gateway Metrics Filter: 网关指标,提供监控指标
  • Forward Routing Filter: 用于本地forword,请求不转发到下游服务器
  • LoadBalancer Client Filter:针对下游服务,实现负载均衡

更多过滤器参考: Global Filters

8.服务部署流程

1.确认配置

2.打包, 上传包到服务器

3.启动服务

4.开启端口号

5.测试

具体部署课看博主javaee初级篇文章 - Linux基本使用与部署

ateway中的全局过滤器,它和GatewayFilter的作用是相同的.

GlobalFilter 会应用到所有的路由请求上,全局过滤器通常用于实现与安全性,性能监控和日志记录等相关的全局功能.

SpringCloud Gateway 内置的全局过滤器也有很多,比如:

  • Gateway Metrics Filter: 网关指标,提供监控指标
  • Forward Routing Filter: 用于本地forword,请求不转发到下游服务器
  • LoadBalancer Client Filter:针对下游服务,实现负载均衡

更多过滤器参考: Global Filters

感谢各位读者的阅读,本文章有任何错误都可以在评论区发表你们的意见,我会对文章进行改正的。如果本文章对你有帮助请动一动你们敏捷的小手点一点赞,你的每一次鼓励都是作者创作的动力哦!😘

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2112746.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

FPGA实现串口升级及MultiBoot(二)FPGA启动流程

这个系列开篇肯定要先了解FPGA的启动流程,试想一下:我想实现MultiBoot,那么我应该在什么时候开始升级,升级失败后FPGA进行了哪些操作,以及怎么回到Golden区? 还有一个问题,就是我硬件打板回来&a…

Chrome下载视频的插件

大家好,我是爱编程的喵喵。双985硕士毕业,现担任全栈工程师一职,热衷于将数据思维应用到工作与生活中。从事机器学习以及相关的前后端开发工作。曾在阿里云、科大讯飞、CCF等比赛获得多次Top名次。现为CSDN博客专家、人工智能领域优质创作者。喜欢通过博客创作的方式对所学的…

SprinBoot+Vue个性化旅游推荐系统的设计与实现

目录 1 项目介绍2 项目截图3 核心代码3.1 Controller3.2 Service3.3 Dao3.4 application.yml3.5 SpringbootApplication3.5 Vue 4 数据库表设计5 文档参考6 计算机毕设选题推荐7 源码获取 1 项目介绍 博主个人介绍:CSDN认证博客专家,CSDN平台Java领域优质…

数学建模_数据预处理流程(全)

数据预处理整体流程图 一般数据预处理流程 处理缺失值:填补或删除缺失值。处理异常值:检测并处理异常值。数据编码:将分类变量进行标签编码或独热编码。数据标准化/归一化:对数据进行标准化或归一化处理。连续变量离散化&#xff…

人机交互系统中的人脸讲话生成系统调研

《Human-Computer Interaction System: A Survey of Talking-Head Generation》 图片源:https://github.com/Yazdi9/Talking_Face_Avatar 目录 前言摘要一、背景介绍二、人机交互系统体系结构2.1. 语音模块2.2. 对话系统模块2.3. 人脸说话动作生成 三 人脸动作生成…

基于人工智能的语音情感识别系统

目录 引言项目背景环境准备 硬件要求软件安装与配置系统设计 系统架构关键技术代码示例 数据预处理模型训练模型预测应用场景结论 1. 引言 语音情感识别是人工智能的一项重要应用,旨在通过分析语音信号中的特征来判断说话者的情感状态,如“愤怒”、“…

1800 万,财务自由了

《黑神话:悟空》 距离《黑神话:悟空》上线(8 月 20 日)上线已过去半个月,从刚开始全网热议,连官方都下场点评,到现在的逐渐回归平静。 不是游戏圈或是对数据不敏感的网友,可能会落入…

【路径规划】 使用计算机视觉和机器人操纵器绘制肖像

摘要 本项目展示了使用计算机视觉和机械臂绘制肖像的完整流程。系统利用网络摄像头获取肖像图像,经过图像处理后生成路径,然后利用逆向运动学将路径转化为机械臂的运动轨迹,最终在硬件机器人上执行绘制。实验结果表明,该系统能够…

【人工智能学习笔记】2_数据处理基础

数据的概述 数据(Data)的定义 用于表示客观事物的未经加工的原始素材不仅指狭义上的数字,也只具有一定意义的文字、字母、数字符号的组合客观事物的属性、数量、位置及其相互关系的抽象表示 在计算机科学与技术领域中,数据是指…

微信小程序和普通网页有什么不同

微信小程序和普通网页的区别主要体现在文件后缀、运行原理、运行环境、开发规则以及标签名等方面。微信小程序于2016年推出,依托微信庞大的用户基础,迅速成为移动应用中的佼佼者,而普通网页则基于传统的HTML、CSS和JavaScript技术构建。以下将…

2024年四川省安全员B证证考试题库及四川省安全员B证试题解析

题库来源:安全生产模拟考试一点通公众号小程序 2024年四川省安全员B证证考试题库及四川省安全员B证试题解析是安全生产模拟考试一点通结合(安监局)特种作业人员操作证考试大纲和(质检局)特种设备作业人员上岗证考试大…

C语言深度剖析--不定期更新的第三弹

hello,everybody!最近又更新了哈,希望对大家有所帮助 switch case关键字 基本语法: switch(整型变量/常量/整型表达式){case 1:var 1;break;case 2:var 2;break;case 3:var 3;break;default:break; }switch case语句也和if语句一样具有判断和分支的功…

第4章-02-用WebDriver驱动浏览器页面截图

🏆作者简介,黑夜开发者,CSDN领军人物,全栈领域优质创作者✌,CSDN博客专家,阿里云社区专家博主,2023年CSDN全站百大博主。 🏆数年电商行业从业经验,历任核心研发工程师,项目技术负责人。 🏆本文已收录于专栏:Web爬虫入门与实战精讲,后续完整更新内容如下。 文章…

NX重要操作函数调用流程

1.文件打开 2.鼠标移动操作 3.定时器

Vue3+Ts封装类似于Element-plus的图片预览组件

组件目录结构如下: options.ts文件用来存储配置文件, 代码如下: import {isFirefox} from ./tools;export type ImageViewerAction = zoomIn | zoomOut | clocelise | anticlocelise;export const mousewheelEventName = isFirefox() ? DOMMouseScroll : mousewheel;// 键…

自然语言处理系列五十三》文本聚类算法》文本聚类介绍及相关算法

注:此文章内容均节选自充电了么创始人,CEO兼CTO陈敬雷老师的新书《自然语言处理原理与实战》(人工智能科学与技术丛书)【陈敬雷编著】【清华大学出版社】 文章目录 自然语言处理系列五十三文本聚类算法》文本聚类介绍及相关算法K…

isalnum函数讲解 <ctype.h>头文件函数

目录 ​1.头文件 2.isalnum函数讲解​​​​​​​ 方源一把抓住VS2022&#xff0c;顷刻 炼化&#xff01; 1.头文件 以上函数都需要包括头文件<ctype.h> &#xff0c;其中包括 isalnum 函数 #include<ctype.h> 2.isalnum函数讲解 isalnum函数是一种判断字符…

解决:Module build failed (from ./node_modules/sass-loader/dist/cjs.js)问题

一、问题 Module build failed (from ./node_modules/sass-loader/dist/cjs.js): Error: Cannot find module sass 二、解决方法 1.清除缓存 npm cache clean --force2.重构项目 npm install 3.更新&#xff08;获取最新的&#xff09;node-sass和sass-loader依赖包 npm …

OpenAI SORA团队负责人 通往智能的方式 报告笔记

OpenAI SORA团队负责人 通往智能的方式 报告笔记 这个报告其实是2024年智源大会的主旨报告&#xff0c;OpenAI SORA和DALL-E团队负责人Aditya Ramesh给出的一段有关多模态大模型的报告。我去听了现场&#xff0c;感觉倍受启发&#xff0c;但是感觉很多并不能当场理解&#xff…

赢麻了!算法学不懂都来翻烂这本书,吊打国内所有晦涩难懂的毒教材!!

这本书巧妙的运用了简洁的图表和示意图&#xff0c;帮助读者更加直观的理解各种机器学习算法的工作原理和应用场景。 就是一本既全面又容易上手的机器学习宝典&#xff0c;适合各种水平的读者&#xff0c;不管你是对AI感兴趣的爱好者&#xff0c;还是正在从事相关工作的专业人…