当前位置: 首页 > news >正文

Spring Cloud Gateway

zuul终究还是被时代淘汰了,spring基本上也逐渐放弃了Netflix平台,自己搞起了gateway。这不得不聊起一个人 Spencer Gibb,他是zuul的核心开发,带领一群有志青年,放弃zuul,转战spring cloud gateway。

应用搭建

其maven依赖如下:

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-gateway</artifactId></dependency>

之后,只需要写个简单的spring boot程序就可以了,与zuul不同的是,gateway没有@Enable开头的开关:

@SpringBootApplicationpublicclassGatewayApplication{publicstaticvoidmain(String[]args){SpringApplication.run(GatewayApplication.class,args);}}

这就是gateway与zuul设计哲学的不同。

网关配置

光完成上述代码肯定不够,因为没有配置转发。以下是配置文件的一个例子:

server:port:80# 网关端口spring:cloud:gateway:routes:-id:user_route# 直接写死目标服务的 IP 和端口uri:http://127.0.0.1:8001predicates:-Path=/user/**

之后就可以正常转发了。

谓词配置

配置中的predicates是gateway的谓词,这部分可谓非常复杂了。上述例子里用的是路径谓词。此外我还整理了其他比较好用的谓词.

谓词名称用途典型场景
Path匹配请求路径/api/转发给某个服务
Query匹配请求参数根据 URL 中的参数(如版本号)分流
Header匹配请求头根据User-Agent或自定义 Header 鉴权
Method匹配请求方法只允许 GET 或 POST 请求通过
Cookie匹配 Cookie针对特定用户群体的灰度发布
Host匹配域名基于域名的路由(如*.abc.com
RemoteAddr匹配客户端 IP黑白名单、IP 限流
After/Before匹配时间活动期间开启特定页面,或维护窗口

过滤器

除了谓词以外,gateway还提供了过滤器配置,以达到更精致的网关控制。以下是常见的过滤器:

分类过滤器名称 (Filter Name)核心作用
请求处理AddRequestHeader给请求头添加自定义信息
AddRequestParameter给请求添加参数
RewritePath重写请求路径(最常用)
StripPrefix截断请求路径前缀
RequestRateLimiter请求限流(令牌桶算法)
响应处理AddResponseHeader给响应头添加信息
DedupeResponseHeader去除响应头中重复的值
SetStatus修改返回的状态码
路由增强Hystrix熔断保护(旧版)
RequestSize限制请求包大小
Retry失败自动重试

转发实现

gateway是怎么转发的?gateway是基于WebFlux技术的。gateway写了一个RoutePredicateHandlerMapping,该类实现了HandlerMapping接口,所以充当了传统servlet里控制器的角色。核心方法在lookupRoute里。在追踪gateway源码时我们可以记录一下堆栈的变化。

  1. 线程Thread[reactor-http-nio-2,5,main]

at org.springframework.cloud.gateway.handler.RoutePredicateHandlerMapping.lookupRoute(RoutePredicateHandlerMapping.java:128)
at org.springframework.cloud.gateway.handler.RoutePredicateHandlerMapping.getHandlerInternal(RoutePredicateHandlerMapping.java:87)
at org.springframework.web.reactive.handler.AbstractHandlerMapping.getHandler(AbstractHandlerMapping.java:181)

  1. 线程Thread[reactor-http-nio-2,5,main]

at org.springframework.cloud.gateway.handler.FilteringWebHandler.handle(FilteringWebHandler.java:77)
at org.springframework.web.reactive.result.SimpleHandlerAdapter.handle(SimpleHandlerAdapter.java:45)
at org.springframework.web.reactive.DispatcherHandler.invokeHandler(DispatcherHandler.java:161)

  1. 线程Thread[reactor-http-nio-2,5,main]

at org.springframework.cloud.gateway.filter.NettyRoutingFilter.filter(NettyRoutingFilter.java:104)
at org.springframework.cloud.gateway.handler.FilteringWebHandler$GatewayFilterAdapter.filter(FilteringWebHandler.java:138)
at org.springframework.cloud.gateway.filter.OrderedGatewayFilter.filter(OrderedGatewayFilter.java:44)

NettyRoutingFilter这个类里终于找到了转发的代码了,我只贴一行代码,不过这行代码可够长的了:

Flux<HttpClientResponse>responseFlux=this.httpClient.headers(headers->{headers.add(httpHeaders);if(preserveHost){Stringhost=request.getHeaders().getFirst(HttpHeaders.HOST);headers.add(HttpHeaders.HOST,host);}else{// let Netty set it based on hostnameheaders.remove(HttpHeaders.HOST);}}).request(method).uri(url).send((req,nettyOutbound)->{if(log.isTraceEnabled()){nettyOutbound.withConnection(connection->log.trace("outbound route: "+connection.channel().id().asShortText()+", inbound: "+exchange.getLogPrefix()));}returnnettyOutbound.send(request.getBody().map(dataBuffer->((NettyDataBuffer)dataBuffer).getNativeBuffer()));}).responseConnection((res,connection)->{// 省略很多很多代码。。。。。。。returnMono.just(res);});
http://www.rkmt.cn/news/183415.html

相关文章:

  • UDP-酮半乳糖二钠盐——赋能前沿糖基化研究的核心工具分子
  • 把织物上的“轻微脏污”抓出来:客户下单50台
  • Java毕设项目:基于SpringBoot+Vue的二手数码产品交易平台的开发与实现(源码+文档,讲解、调试运行,定制等)
  • LLM解析脑电波,中风康复预测提前1月
  • Amaze File Manager:一款基于 Material Design 的开源安卓文件管理器
  • 综合实践
  • Java毕设选题推荐:基于SpringBoot+Vue的具有推荐功能的二手交易基于SpringBoot+Vue的二手数码产品交易平台的开发与实现【附源码、mysql、文档、调试+代码讲解+全bao等】
  • Java毕设选题推荐:基于SpringBoot社区住户信息管理系统基于web的社区居民信息管理系统【附源码、mysql、文档、调试+代码讲解+全bao等】
  • Alpine.js:轻量级JavaScript框架完全入门指南
  • 网易云音乐ncm加密转mp3格式
  • 京东多智能体———多源异构数据采集与融合应用综合实践
  • 计算机Java毕设实战-基于SpringBoot社区住户信息管理系统【完整源码+LW+部署说明+演示视频,全bao一条龙等】
  • 揭秘CopyOnWriteArraySet:读多写少的并发集合利器
  • 学生党论文降AI率,前五工具够用了
  • 机械制图 - Ac1d
  • 论文降AI别瞎改,这五佳工具效率高
  • 儿童近视度数增长过快?眼调节训练灯破解“度数逐年递增”困扰!
  • 五佳降AI工具合集,速降到合格线内
  • 【课程设计/毕业设计】基于SpringBoot的汽车配件仓储管理配件档案 - 出入库管理 - 库存监控系统设计与实现【附源码、数据库、万字文档】
  • 项目风险预警:智能分析系统
  • 09. 图像的阈值处理
  • Zed编辑器安装与使用Agent Servers(腾讯CodeBuddy、阿里百炼Qwen Code、DeepSeek Cli)
  • Kingbase-KEMCC配置集群监控纳管ES以及外部备份使用对象存储
  • Java毕设选题推荐:基于SpringBoot+Vue的汽车配件仓储管理系统管理系统设计基于SpringBoot的汽车配件仓储管理系统设计与实现【附源码、mysql、文档、调试+代码讲解+全bao等】
  • 【基于LLaMA-Factory通义千问】大模型微调全流程技术解析
  • UDP-N-叠氮乙酰葡萄糖胺二钠盐:糖蛋白化学生物学研究的关键工具
  • 【计算机毕业设计案例】基于SpringBoot的学校图书管理系统设计与实现图书管理、借阅记录、审核借阅、图书续借、审核续借、确认归还(程序+文档+讲解+定制)
  • AI+SQL生成ER图
  • 从Java全栈开发到云原生实践:一次真实面试的深度记录
  • P5607 [Ynoi2013] 无力回天 NOI2017 题解