Spring Cloud Alibaba: Gateway 网关过滤器 GatewayGatewayFilter factory (记录)
目录
AddRequestHeader GatewayFilter factory
AddRequestHeadersIfNotPresent GatewayFilter factory
AddRequestParameter GatewayFilter Factory
AddResponseHeader GatewayFilter Factory
CircuitBreaker GatewayFilter factory
circuit breaker based on the status code
PrefixPath GatewayFilter factory
StripPrefix GatewayFilter factory
RewritePath GatewayFilter factory
RequestRateLimiter GatewayFilter factory
default-filters
自定义GatewayFilter
多filter的运行
AddRequestHeader
GatewayFilter
factory
添加对应key和value
server:port: 9000
spring:cloud:gateway:routes:- id: my_routeuri: http://localhost:7070predicates:- Path=/info/**filters:- AddRequestHeader=X-Request-Color, blue
controller获取请求头遍历输出
postman加请求头也能输出
AddRequestHeadersIfNotPresent
GatewayFilter
factory
可以添加多组key和value(请求头不存在对应key的情况下)
server:port: 9000
spring:cloud:gateway:routes:- id: my_routeuri: http://localhost:7070predicates:- Path=/info/**filters:- AddRequestHeadersIfNotPresent=X-Request-Color:blue,school:rjxy
@GetMapping("/allHeaders")public String allHeadersHandle(HttpServletRequest request){StringBuilder sb = new StringBuilder();//获取请求头所有的keyEnumeration<String> headerNames = request.getHeaderNames();//遍历所有keywhile (headerNames.hasMoreElements()) {//获取keyString name = headerNames.nextElement();sb.append(name+"===");//获取当前key的所有valueEnumeration<String> headers = request.getHeaders(name);//遍历所有valuewhile (headers.hasMoreElements()) {//将当前遍历的value追加到sb中sb.append(headers.nextElement()+"");}sb.append("<br>");
}return sb.toString();}
controller进行请求头遍历输出,添加成功
AddRequestParameter
GatewayFilter
Factory
添加请求参数
server:port: 9000
spring:cloud:gateway:routes:- id: my_routeuri: http://localhost:7070predicates:- Path=/info/**filters:- AddRequestParameter=red, blue
controller
@GetMapping("/params")public String paramsHandle(String red){
return red;}
获取成功
AddResponseHeader
GatewayFilter
Factory
响应修改
server:port: 9000
spring:cloud:gateway:routes:- id: my_routeuri: http://localhost:7070predicates:- Path=/info/**filters:- AddResponseHeader=X-Response-color, Blue- AddResponseHeader=X-Response-color, Red
直接F12查看响应头,添加成功
CircuitBreaker GatewayFilter factory
熔断过滤工厂,完成网关层的服务熔断与降级
server:port: 9000
spring:cloud:gateway:routes:- id: my_routeuri: http://localhost:7070predicates:- Path=/info/**filters:- name: CircuitBreakerargs:name: myCircuitBreakerfallbackUri: forward:/fb
访问http://localhost:7070不成功时,降级访问forward:/fb
降级controller
@GetMapping("/fb")public String fallbackHandle(){return "This is the Gateway Fallback";}
测试,直接不启动7070,访问9000,熔断成功
circuit breaker based on the status code
PrefixPath
GatewayFilter
factory
server:port: 9000
spring:cloud:gateway:routes:- id: my_routeuri: http://localhost:8081predicates:- Path=/student/**filters:- PrefixPath=/provider
匹配字段,加上前缀,子模块自动添加路径
测试成功
StripPrefix
GatewayFilter
factory
去除指定的请求路径
server:port: 9000
spring:cloud:gateway:routes:- id: my_routeuri: http://localhost:8081predicates:- Path=/aa/bb/provider/student/**filters:- StripPrefix=2
去除/aa/bb
测试成功
RewritePath
GatewayFilter
factory
重写路径
server:port: 9000
spring:cloud:gateway:routes:- id: my_routeuri: http://localhost:8081predicates:- Path=/red/blue/**filters:- RewritePath=/red/blue,/provider/student// - RewritePath=/red/?(?<segment>.*), /$\{segment}
匹配路径,替换成指定路径
RequestRateLimiter
GatewayFilter
factory
通过令牌桶算法对进来的请求进行限流
导入依赖
<!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-data-redis-reactive -->
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis-reactive</artifactId><version>3.0.5</version>
</dependency>
添加限流键解析器
在启动类中添加一个限流键解析器,其用于从请求中解析出需要限流的key。
本例指定的是根据请求的host或ip进行限流。
package com.guo;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.gateway.filter.ratelimit.KeyResolver;
import org.springframework.context.annotation.Bean;
import reactor.core.publisher.Mono;
@SpringBootApplication
public class Application {
public static void main(String[] args) {SpringApplication.run(Application.class, args);}
@BeanKeyResolver userKeyResolver() {return exchange -> Mono.just(exchange.getRequest().getRemoteAddress().getHostName());}
}
修改配置文件
server:port: 9000
spring:cloud:gateway:routes:- id: my_routeuri: http://localhost:8081predicates:- Path=/**filters:
# replenishRate 填充率- name: RequestRateLimiterargs:key-resolver: "#{@userKeyResolver}"redis-rate-limiter.replenishRate: 2redis-rate-limiter.burstCapacity: 5redis-rate-limiter.requestedTokens: 1data:redis:host: 127.0.0.1port: 6379
成功
default-filters
server:port: 9000
spring:cloud:gateway:default-filters:- AddRequestHeader=X-Request-Color, Default-Blueroutes:- id: my_routeuri: http://localhost:7070predicates:- Path=/info/header
- id: my_routeuri: http://localhost:7070predicates:- Path=/info/headers
测试成功
自定义GatewayFilter
AddHeaderGatewayFilter.java
public class AddHeaderGatewayFilter implements GatewayFilter {@Overridepublic Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {ServerHttpRequest request = exchange.getRequest().mutate().header("X-Request-Color", "filter-Red").build();ServerWebExchange webExchange = exchange.mutate().request(request).build();return chain.filter(webExchange);}
}
调用自定义的GatewayFilter
@Bean
public RouteLocator routeLocator(RouteLocatorBuilder builder){return builder.routes().route("my_router2",ps ->ps.path("/info/**").filters(fs->fs.filter(new AddHeaderGatewayFilter())).uri("http://localhost:7070")).build();
}
测试成功
多filter的运行
OneGateWayFilter.java
@Slf4j
public class OneGateWayFilter implements GatewayFilter {@Overridepublic Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {long startTime = System.currentTimeMillis();log.info("oneFilter-pre:"+startTime);exchange.getAttributes().put("startTime",startTime);return chain.filter(exchange).then(Mono.fromRunnable(()->{log.info("oneFilter------post");Long startTimeAttr = (Long) exchange.getAttributes().get("startTime");long elaspedTime = System.currentTimeMillis() - startTimeAttr;log.info("所有过滤器执行的时间(毫秒)为:"+elaspedTime);}));}
}
TwoGateWayFilter.java
@Slf4j
public class TwoGateWayFilter implements GatewayFilter {@Overridepublic Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {log.info("TwoFilter----pre");return chain.filter(exchange).then(Mono.fromRunnable(()->{log.info("TwoFilter------post");}));}
}
ThreeGateWayFilter.java
@Slf4j
public class ThreeGateWayFilter implements GatewayFilter {@Overridepublic Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {log.info("ThreeFilter----pre");return chain.filter(exchange).then(Mono.fromRunnable(()->{log.info("ThreeFilter------post");}));}
}
测试结果
相关文章:

Spring Cloud Alibaba: Gateway 网关过滤器 GatewayGatewayFilter factory (记录)
目录 AddRequestHeader GatewayFilter factory AddRequestHeadersIfNotPresent GatewayFilter factory AddRequestParameter GatewayFilter Factory AddResponseHeader GatewayFilter Factory CircuitBreaker GatewayFilter factory circuit breaker based on the status…...

Windows Server 2016版本说明
Windows Server 2016 Essentials edition Windows Server 2016 Essentials版是专为小型企业而设计的。它对应于Windows Server的早期版本中的Windows Small Business Server。此版本最多可容纳25个用户和50台设备。它支持两个处理器内核和高达64GB的RAM。它不支持Windows Serve…...

车载红外夜视「升温」
红外夜视赛道,正在升温。 本周,全球车载后视镜头部供应商Gentex宣布,领投以色列热成像技术初创公司ADASKY,后者在B轮融资中拿到了3000万美元。按照计划,Gentex将协助ADASKY将红外夜视技术推向汽车市场。 事实上&#x…...

ext3 文件系统的特点、优缺点以及使用场景
ext3(Third Extended File System)是 ext2 文件系统的后续版本,它在 ext2 文件系统的基础上增加了日志功能,以提高文件系统的可靠性和稳定性。下面是 ext3 文件系统的特点、优缺点以及使用场景: 特点: ext…...

rk3568 修改开机logo
rk3568 修改开机显示logo Android 显示 logo 的作用是为了标识应用程序或设备的品牌和身份。在应用程序中,logo 可以帮助用户快速识别应用程序,并与其他应用程序区分开来。在设备中,logo 可以帮助用户识别设备的品牌和型号,以及与…...

golang实现关键路径算法
关键路径算法(Critical Path Method,简称CPM)是一种用于项目管理的技术,主要用于计算项目中的关键路径和关键活动。关键路径是指项目中的最长路径,决定了项目的最短完成时间。关键活动是指在关键路径上的活动ÿ…...

Overcoming catastrophic forgetting in neural networks
目录 预备知识: 论文笔记 1. Introduction 2. Elastic weight consolidation 2.1 EWC allows continual learning in a supervised learning context 2.2 EWC allows continual learning in a reinforcement learning context 3. Conclusion 文章链接&#x…...

[Linux] Linux文件系统
🥁作者: 华丞臧. 📕专栏:【LINUX】 各位读者老爷如果觉得博主写的不错,请诸位多多支持(点赞收藏关注)。如果有错误的地方,欢迎在评论区指出。 文章目录 一、Linux文件系统1.1 磁盘1.2 inode1.3 软硬…...

有仰拍相机和俯拍相机时,俯拍相机中心和吸嘴中心的标定
俯拍相机中心和吸嘴中心的标定 文章目录 俯拍相机中心和吸嘴中心的标定 前言适用模型如下:一、使用一个标定片进行标定1.关键注意:2.标定步骤: 二、使用一个L型的工件1.关键注意:2.标定步骤: 总结 前言 在自动化设备领…...

【Vue学习笔记5】Vue3中的响应式:ref和reactive、watchEffect和watch
所谓响应式就是界面和数据同步,能实现实时更新。 Vue 中用过三种响应式解决方案,分别是 defineProperty、Proxy 和 value setter。Vue 2 使用的方案是 defineProperty API。Vue3中使用的方案是Proxy和value setter。 1. ref和reactive vue3中实现响应…...

自动化测试工具的基本原理以及应用场景
自动化测试工具是现代软件开发流程中必不可少的组成部分,它可以通过编写脚本或使用图形用户界面工具自动化测试过程,提高测试的效率和准确性。本文将介绍自动化测试工具的基本原理以及应用场景。 自动化测试工具的基本原理 自动化测试工具通常采用的原理…...

《Java虚拟机学习》 java代码的运行过程
1. Java文件转换 当我们保存java文件后,首先由编译器编译成class文件,然后通过Java虚拟机将class文件转换成字节码文件 2.Java虚拟机是怎么运行Java文件 首先将java文件加载到java虚拟机中,然后由虚拟机将类元信息存储在 虚拟机的方法区中。…...

关于Intel处理器架构中AVX2里Gather特性的说明
在 Intel Haswell 架构里引入了 Gather 特性。它使得CPU可以使用向量索引存储器编址从存储器取非连续的数据元素。这些gather指令引入了一种新的存储器寻址形式,该形式由一个 基地址寄存器(仍然是通用目的寄存器)和通过一个 向量寄存器&#…...

UNIX常用命令(C站最全,一文通关)
unix常见命令列举如下,除了看还要会用: ls - 列出目录下的文件 cd - 切换目录 pwd - 显示当前目录 mkdir - 创建目录 rm - 删除文件或目录 rmdir - 删除空目录 cp - 复制文件或目录 mv - 移动文件或目录,或重命名 cat - 显示文件内容 less - 分…...

Vue监听属性详细讲解
文章目录 定义要监听的属性定义 watch修改监听的属性值监听数组变化监听对象变化监听计算属性变化监听事件变化监听路由变化 在 Vue 中,可以使用 watch/$watch 方法监听数据、计算属性、事件和路由的变化,从而实现数据绑定、事件监听和路由控制等功能。需…...

网申形式一览:这三种投递方式,你了解吗?
银行校招是个滚动的过程,每家银行的网申期并不一致。想要在看重的银行网申期投出一份漂亮的简历,简历自身要“过硬”。是不是还有同学不清楚网申简历形式? 从如信银行考试中心了解到,银行网申,尤其是大行网申ÿ…...

vue项目将多张图片生成一个gif动图
当前做项目有一个需求是将多张图片生成一个gif动图的形式 类似下面图片几张图片叠加生成一个gif动图 图片涉及工作隐私,就不公开啦 我们要引入一个gif.js的引入包,但是他没有直接引入的方式,只能从官方下载文件包,下载地址&#…...

开心档之Go 语言常量
Go 语言常量 常量是一个简单值的标识符,在程序运行时,不会被修改的量。 常量中的数据类型只可以是布尔型、数字型(整数型、浮点型和复数)和字符串型。 常量的定义格式: const identifier [type] value你可以省略类…...

动态库和静态库的使用
一、什么是库? 库是一种可执行代码的二进制形式,可以被操作系统载入内存执行。就是将源代码转化为二进制格式的源代码,相当于进行了加密,别人可以使用库,但是看不到库中的内容。 常见的库类型 共享库 静态库 动态库…...

前端:20 个常见的前端算法题
现在面试中,算法出现的频率越来越高了,大厂基本必考 今天给大家带来 20 个常见的前端算法题,重要的地方已添加注释,如有不正确的地方,欢迎多多指正 💕 1、两数之和 题目: 给定一个数组 nums …...

【Linux】多线程 --- 线程概念 控制 封装
从前种种,譬如昨日死。从后种种,往如今日生。 文章目录 一、线程概念1.重新理解用户级页表1.1 进程资源如何进行分配呢?(地址空间页表)1.2 虚拟地址如何转换到物理地址?(页目录页表项࿰…...

最长递增子序列的长度 _ 贪心+二分查找 _ 20230510
最长递增子序列的长度 _ 贪心二分查找 _ 20230510 前言 最长递增子序列的程序一般采用动态规划方式,使用bottom-up的数组记忆方式比较容易理解,当然也可以采用top-down的递归模式。本文主要讨论如何利用贪心策略,同时辅助以二分查找的方式实…...

VMware ESXi 7.0 U3m Unlocker OEM BIOS 集成网卡驱动和 NVMe 驱动 (集成驱动版)
ESXi 7 U3 标准版集成 Intel 网卡、USB 网卡 和 NVMe 驱动 请访问原文链接:https://sysin.org/blog/vmware-esxi-7-u3-sysin/,查看最新版。原创作品,转载请保留出处。 作者主页:sysin.org 2023-05-03,发布 ESXi 7.0U…...

Scrum敏捷开发和项目管理流程及工具
Scrum是全球运用最广泛的敏捷管理框架,Leangoo基于Scrum框架提供了一系列的流程和模板,可以帮助敏捷团队快速启动Scrum敏捷开发。 这里可以介绍一下在scrum中单团队敏捷开发如何管理,单团队敏捷开发主要是针对10-15人以下,只有一…...

微服务之配置中心
文章目录 1什么是配置2什么是配置中心3为什么我们要用配置中心4特点 1什么是配置 就是springboot中的application.yml/properties文件 比如:项目名、端口号、数据库连接参数、启动参数等。 2什么是配置中心 配置中心就是用来管理项目当中所有配置的系统ÿ…...

windows下安装OpenCL
由于我的电脑是windows10,显卡是集显Intel UHD Graphics 630。 下载Intel的SDK for OpenCL,下载地址https://software.intel.com/en-us/opencl-sdk/choose-download,也可以在我的资源里面直接下载https://download.csdn.net/download/qq_363…...

前端项目的通用优化策略
一、虚拟滚动 当我们开发的时候,遇到大数据加载,页面卡顿的问题应该如何处理?大多数情况下,我们都是尽量通过分页的方式处理这类问题,但是总有一些特殊的情况我们必须把数据全部加载到前端进行处理。我曾经遇到过一个…...

关于 IO、存储、硬盘和文件系统
关于IO、存储、硬盘和文件系统 0.引入1.了解IO1.1.存储器IO1.2.设备IO 2.存储介质和存储类型2.1.内存2.2.硬盘2.3.固态硬盘(SSD)2.4.U盘 3.硬盘的工作原理3.1.磁头3.2.盘片3.3.电动机3.4.硬盘的读写操作 4.文件系统概述4.1.文件系统的类型4.2.文件系统的…...

计算机网络期中复习提纲-酷酷的聪整理版
第一章 概述 1.请介绍计算机网络在逻辑上的组成及其各自的作用。 计算机网络在逻辑上可以分为终端子网和通信子网两部分。 终端子网是指连接计算机与网络的部分,主要负责将数据从计算机发送到通信子网,或将从通信子网接收到的数据传输到计算机。终端子网通常包括物理层和数据…...

clickhouse的嵌套数据结构Tuple、Array与Nested类型介绍和使用示例
文章目录 Tuple类型Array类型Nested类型使用示例单独使用Tuple数组嵌套 Array(Tuple)Nested类型 生产使用:分组查询 Tuple类型 Tuple是ClickHouse数据库中的一种数据类型,它允许在一个字段中存储由不同数据类型组成的元组(tuple)。元组可以包含任意数量…...