路由转发和过滤
1.pom
org.springframework.cloud/spring-cloud-starter-gateway
//# 限流
com.alibaba.csp/sentinel-spring-cloud-gateway-adapter
2.配置文件
spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848
//# 开启从注册中心拉取服务列表动态创建路由
spring.cloud.gateway.discovery.locator.enabled=true
//#
spring.cloud.gateway.routes:
- id: nacos-gateway-provider
uri: lb://spring-cloud-nacos-gateway-provider
predicates:
- Path=/scngp/**
filters:
- StripPrefix=1
----------------------------------------------
gateway 收到请求后,predicate 谓词匹配选择路由,根据过滤器链在请求转发前后做处理
----------------------------------------------
route predicate factories
---------------------------
时间规则匹配
cookie 匹配
header 匹配
host 匹配
method 匹配
path 匹配
query 匹配
remoteAddr 匹配
----------------------------------------------
filter factories
---------------------------
pre
转发请求之前执行,可以做 鉴权 限流
---------------------------
post
网关收到后台请求响应 返回给客户端之前执行
----------------------------------------------
filter
gateway filter 应用于单个 filter 或 一组 filter
global filter 应用于所有路由
----------------------------------------------
gateway filter
---------------------------
AddRequestParameter
对匹配的请求增加一个查询参数
---------------------------
AddResponseHeader
对匹配的请求 增加 response header
---------------------------
RequestRateLimiter
默认实现 RedisRateLimiter,采用了令牌桶算法实现限流
replenishRate 令牌填充速度,代表允许每秒通过的请求数
burstCapacity 令牌桶的容量,代表每秒用户最大能执行的请求数量
---------------------------
retry
重试过滤器,当后端请求不可用时,网关根据配置发起重试
retries 请求重试次数,默认值 3
status 执行重试的 http 状态码
methods 执行重试的请求方法类型,默认 GET
series 错误码段,默认 SERVER_ERROR(5),5xx 发起重试
----------------------------------------------
global filter
针对所有的路由配置生效
---------------------------
GatewayMetricsFilter 采集监控数据
LoadBalancerClientFilter 整合 ribbon 负载均衡
如果 uri 配置的是 lb://service1, 通过 LoadBalancerClient 将 service1 替换为某个服务实例的 ip 和端口
ForwardRoutingFilter 用于 forward 本地
NettyRoutingFilter 使用 Netty 的 HttpClient 转发 HTTP/HTTPS 请求
---------------------------
----------------------------------------------
----------------------------------------------