Spring Cloud Gateway (六) 自定义 Global Filter
简介
在前面五篇的分析中,对 Spring Cloud Gateway 的 filter 组件有了一个大概的认知,今天就练练手,写一个统计请求返回时长的 global filter
思路整理
阅读官方文档和在前面读源码的过程中,大致知道 global filter 需要继承 GlobalFilter 、 Ordered
- GlobalFilter : 需要重写 filter 方法,在其中实现自己的处理逻辑,很大部分都是对 exchange 进行操作,取值赋值等等
- Ordered : 需要重写 getOrder 方法,决定自定义 filter 在链中的位置,按照数字大小进行的排序
自定义时长统计 filter 编写
这里就简单的借鉴下 GatewayMetricsFilter 的写法,在 filter 链触发完成后,无论失败或者成功,都进行统计。filter 次序就简单的取 WRITE_RESPONSE_FILTER_ORDER 之后(用它定义的次序减一)。代码大致如下:
/**
* 统计一次请求在filter链中的时长
*
* @author lw1243925457
*/
public class DurationStatisticsFilter implements GlobalFilter, Ordered {
private static final Log log = LogFactory.getLog(DurationStatisticsFilter.class);
private static final String START_STAMP = "startStamp";
/**
* 请求响应时长统计
* 1.首先将请求进来时的时间戳写入到 exchange中
* 2.filter链走完后,无论成功或者失败,都视为完成,从exchange取出开始时间戳,打印时长信息
* @param exchange the current server exchange
* @param chain provides a way to delegate to the next filter
* @return mono
*/
@Override
public Mono<Void>
Spring Cloud Gateway:自定义Global Filter实现请求时长统计

本文介绍了如何在Spring Cloud Gateway中自定义一个Global Filter,用于统计请求的返回时长。首先,讲解了Global Filter需要继承GlobalFilter和Ordered接口,并提供了编写时长统计filter的思路。接着,展示了具体的代码实现,包括在filter链完成后进行统计的逻辑以及设置filter的执行顺序。最后,提到了在主函数中配置bean以运行该filter。
最低0.47元/天 解锁文章

被折叠的 条评论
为什么被折叠?



