天穹-gateway网关系列2:如何设计filter链

本文介绍了如何设计和实现一个filter链路,详细解析了在Gateway中filter的作用,包括定义单个filter、加载filter链以及filter的执行顺序。通过具体的filter示例,展示了filter如何处理请求和响应,以及在filter链中的执行流程。
摘要由CSDN通过智能技术生成

开源地址

https://github.com/XiaoMi/mone/tree/master/gateway-all 欢迎对云原生技术/研发效能感兴趣的小伙伴加入(Fork、Star)我们。

一、网关里的filter链是做什么的

在gateway网关系列文章的第一篇里,我们知道网关的一个核心职能是收敛各个微服务公共非业务功能,如身份验证、监控、负载均衡、缓存等,以尽可能减少各服务的职责。在这里,我们用filter链来实现这个功能。

每个公共功能对应一个filter,比如身份验证filter、负载均衡filter等。网关组织这些filter生成一个有顺序的filter链路。第一步,request请求进入网关后,会顺序经过链路中的每个filter,这个时候我们可以对请求做一些处理。第二步,到达协议转换模块进行协议转换,分发到对应的后端应用并拿到返回结果。第三步,response结果逆序再次经过链路中的每个filter,这里我们可以对返回结果进行一定的处理。

二、设计一个filter链路

1、定义单个filter

  • RequestFilter: filter的抽象类,基于此抽象类实现具体的filter。里面定义了公共类成员变量和doFilter方法等。

  • FilterDef: 用一组数据(id、name)标记filter的唯一性,并额外记录filter的一些信息(version、author等)。

  • Invoker: 串联filter的关键。

  • FilterContext: 用于传递filter的上下文信息,比如ip,headers等

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值