7.统一网关-Gateway

文章目录

  • 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: gatewaycloud:nacos:discovery:server-addr: 110.41.51.65:10020gateway:metrics:enabled: trueroutes:- 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-serviceuri: lb://product-service/predicates:- Path=/product/**default-filters:- name: Retryargs:retries: 3statuses: 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_routeuri: http://httpbin.orgpredicates:- Path=/foo/**  # 匹配所有以 /foo/ 开头的请求=

4.2.Method 路由断言工厂

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

spring:cloud:gateway:routes:- id: method_routeuri: http://httpbin.orgpredicates:- Method=GET  # 匹配所有 GET 请求

4.3 Header 路由断言工厂

根据请求头的值匹配路由

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

4.4 Query 路由断言工厂

根据查询参数匹配路由

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

4.5 Host 路由断言工厂

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

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

4.6 After 路由断言工厂

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

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

4.7 Before 路由断言工厂

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

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

4.8 Between 路由断言工厂

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

spring:cloud:gateway:routes:- id: between_routeuri: http://httpbin.orgpredicates:- 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_routeuri: https://example.orgpredicates:- 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_routeuri: https://example.orgpredicates:- Host: {segment}.myhost.orgfilters:- AddRequestParameter=foo, bar-{segment}

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

5.3 The AddResponseHeader GatewayFilter Factory

spring:cloud:gateway:routes:- id: add_response_header_routeuri: https://example.orgpredicates:- Host: {segment}.myhost.orgfilters:- AddResponseHeader=foo, bar-{segment}

5.4 The DedupeResponseHeader GatewayFilter Factory

spring:cloud:gateway:routes:- id: dedupe_response_header_routeuri: https://example.orgfilters:- 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_routeuri: lb://backing-service:8088predicates:- Path=/consumingServiceEndpointfilters:- name: CircuitBreakerargs:name: myCircuitBreakerfallbackUri: forward:/inCaseOfFailureUseThis- RewritePath=/consumingServiceEndpoint, /backingServiceEndpoint

5.6 The FallbackHeaders GatewayFilter Factory

spring:cloud:gateway:routes:- id: ingredientsuri: lb://ingredientspredicates:- Path=//ingredients/**filters:- name: CircuitBreakerargs:name: fetchIngredientsfallbackUri: forward:/fallback- id: ingredients-fallbackuri: http://localhost:9994predicates:- Path=/fallbackfilters:- name: FallbackHeadersargs: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.rhkb.cn/news/418533.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

超声波测距模块HC-SR04(基于STM32F103C8T6HAL库)

超声波测距模块参考资料 1.电路连接及引脚配置 触发信号PA3只需要输出10us的高电平,所以直接设置成 普通的GPIO端口即可;回响信号使用外部中断,上升沿信号产生外部中断,打开定时器,下降沿再产生一次中断,读…

国内外大模型汇总(包括科大星火、文心一言、通义千问、智普清言、华为大模型)

国内外大模型汇总 1. 科大讯飞星火认知大模型 主要特点: 多语言能力:以中文为核心,同时支持多语言处理,能够进行跨语种的语言理解和生成。 广泛的任务能力:具备内容生成、语言理解、知识问答、推理、数学计算、代码…

强化网络安全:通过802.1X协议保障远程接入设备安全认证

随着远程办公和移动设备的普及,企业网络面临着前所未有的安全挑战。为了确保网络的安全性,同时提供无缝的用户体验,我们的 ASP 身份认证平台引入了先进的 802.1X 认证协议,确保只有经过认证的设备才能接入您的网络。本文档将详细介…

Kafka【六】Linux下安装Kafka(Zookeeper)集群

Kafka从早期的消息传输系统转型为开源分布式事件流处理平台系统,所以很多核心组件,核心操作都是基于分布式多节点的。本文这里采用三台虚拟机模拟真实物理主机搭建Zookeeper集群和kafka集群。 VMware可以使用户在一台计算机上同时运行多个操作系统&…

使用AI写WebSocket知识是一种怎么样的体验?

一、WebSocket基础知识 1. WebSocket概念 1.1 为什么会出现WebSocket 一般的Http请求我们只有主动去请求接口,才能获取到服务器的数据。例如前后端分离的开发场景,自嘲为切图仔的前端大佬找你要一个配置信息的接口,我们后端开发三下两下开…

Windows下的Redis启动报错Redis service failed to start

报错原因:Redis服务没有找到log文件 解决方案: 1、在Redis目录下打开redis.windows-service.conf文件 2、找到logfile存放目录,一般默认为Logs/redis_log.txt 3、在Redis目录创建Logs文件夹,在Logs文件夹下创建redis_log.txt文件…

机器学习数学公式推导之降维

文章目录 降维线性降维-主成分分析 PCA损失函数SVD 与 PCoASVD 的基本形式SVD 的计算p-PCA 小结 P22 (系列五) 降维1-背景 本文参考 B站UP: shuhuai008 🌹🌹 降维 我们知道,解决过拟合的问题除了正则化和添加数据之外,降维就是最…

自己部门日均1000+告警?如何减少90%无效告警?

目录标题 一、告警的类别1.技术告警1.1基础设施告警1.2基本服务告警 2.业务告警3.监控大盘告警 二、为何需要告警治理?三、治理迫在眉睫1.1告警治理策略1.2核心监控告警点1.3避免告警反模式1.4告警规约制定1.5自动化处理 一、告警的类别 一般的告警分为以下几点&am…

连续信号的matlab表示

复习信号与系统以及matlab 在matlab中连续信号使用较小的采样间隔来表四 1.单位阶跃信号 阶跃信号:一个理想的单位阶跃信号在时间 t 0 之前值为0,在 t 0 及之后值突然变为常数 A(通常取 A 1) %matlab表示连续信号,是让信号的采样间隔很小…

数据类型转换

1. 基本数据类型转换 1.1 自动类型转换 1.2 注意 1.3 强制类型转换 2. String 与基本数据类型的转换 2.1 基本数据类型转 String public class StringConvert{public static void main(String []args){//基本数据类型-->Stringbyte a1;short b10;int c100;long d1000;…

什么是网络安全?

目录 网络安全定义 网络安全如何运作? 1.人 2.基础设施 3.漏洞 4.技术 网络安全的演变 未来十年的网络安全将会是什么样子? 网络安全为何对企业如此重要? 网络安全的类型 1.网络安全 2.应用程序安全 3.信息安全 4.运营安全 5.灾…

SAP与湃睿PLM系统集成案例

一、项目背景 浙江某家用电机有限公司, 该公司的产品涵盖洗衣机、‌空调、‌冰箱及厨房用具等家电电机的制造,‌具备年产4600万台电机的生产能力,‌是中国最大的家电电机生产基地之一。 为确保工艺路线信息在设计与生产执行层面的无缝传递&#xff0…

c语言——用一维数组输出杨辉三角形

一.代码 #include <stdio.h> int Num[100]; int Hang; int Lie; int a; int Flag; int main() {Lie 1;Hang 1;a 0;while (1) {//列1为1if (Lie 1) {Num[1] 1;Lie;}//数据存到数组里面while (Hang > Lie && Hang ! 2) { if (Hang!Lie) {Flag Num[Lie] …

端口安全老化细节

我们都知道port-security aging-time命令用来配置端口安全动态MAC地址的老化时间&#xff0c;但是后面还可以加上类型&#xff1a; [SW1-GigabitEthernet0/0/1]port-security aging-time 5 type absolute Absolute time 绝对老化 inactivity Inactivity time相对老化 …

原型模式prototype

此篇为学习笔记&#xff0c;原文链接 https://refactoringguru.cn/design-patterns/prototype 能够复制已有对象&#xff0c; 而又无需使代码依赖它们所属的类 所有的原型类都必须有一个通用的接口&#xff0c; 使得即使在对象所属的具体类未知的情况下也能复制对象。 原型对…

形态学运算合集

圆形结构元素 禹晶、肖创柏、廖庆敏《数字图像处理&#xff08;面向新工科的电工电子信息基础课程系列教材&#xff09;》 禹晶、肖创柏、廖庆敏《数字图像处理》资源二维码

Java项目: 基于SpringBoot+mybatis+maven+mysql图书馆管理系统(含源码+数据库+任务书+答辩PPT+毕业论文)

一、项目简介 本项目是一套基于SpringBootmybatismavenmysql图书馆管理系统 包含&#xff1a;项目源码、数据库脚本等&#xff0c;该项目附带全部源码可作为毕设使用。 项目都经过严格调试&#xff0c;eclipse或者idea 确保可以运行&#xff01; 该系统功能完善、界面美观、操…

vue项目打包后,生成的index.html直接本地打开后没内容

应该是文件路径找不到了 可以打开控制台看看 可以看到加载css&#xff0c;js&#xff0c;图标资源失败&#xff0c;所以是文件路径问题 vue-cli工程化生成的项目在打包后&#xff0c;默认的资源寻找路径是根&#xff0c;所以可以看到它直接在/F;/favicon找图标&#xff0c;但…

PMBOK® 第六版 项目进度管理知识领域

目录 读后感—PMBOK第六版 目录 提到“进度”&#xff0c;大家都能直观理解其含义。有统计指出&#xff0c;现在项目的延迟交付比例越来越高&#xff0c;并且这一趋势持续上升。造成项目延期的原因是多方面的&#xff0c;常见的原因之一是在项目初期&#xff0c;由于时间充裕&…

mysql笔记—基础

1.SQL语句 DDL&#xff08;数据库对象操作&#xff09;、DML&#xff08;增删改&#xff09;、DQL&#xff08;查询&#xff09;、DCL&#xff08;用户和权限操作&#xff09; 2.DDL&#xff1a; 1.数据库操作&#xff1a; show databases; create database []; use []; sele…