开源地址
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等