当前位置: 首页 > 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.jsqmd.com/news/167724/

相关文章:

  • 挠弹记录
  • UDP-酮半乳糖二钠盐——赋能前沿糖基化研究的核心工具分子
  • 特斯拉为何死磕纯视觉?成本、数据与安全冗余的自动驾驶路线之争
  • 把织物上的“轻微脏污”抓出来:客户下单50台
  • UDP-2-F-D-葡萄糖胺二钠盐—糖生物学研究与药物开发的关键工具分子
  • 论文AI率超标自救:五佳降AI工具合集
  • 【毕业设计】基于SpringBoot社区住户信息管理系统(源码+文档+远程调试,全bao定制等)
  • 摸鱼没翻车,全靠这套 Chrome 快捷键组合
  • DaBai Max Pro 与 DaBai DCW2-DW2 深度相机坐标系解析
  • Java毕设项目:基于SpringBoot+Vue的二手数码产品交易平台的开发与实现(源码+文档,讲解、调试运行,定制等)
  • 102301338郭砚康的软件工程课程总结 - Nicholas
  • Java计算机毕设之基于SpringBoot+Vue的二手数码产品交易平台的开发与实现(完整前后端代码+说明文档+LW,调试定制等)
  • 通信原理篇---误码率
  • 高达一亿港币人工智能创投基金,亚洲人工智能初创大赛上海站招募丨社区伙伴活动推荐
  • 论文被判AI生成?五佳降AI工具避坑分享
  • 【课程设计/毕业设计】基于SpringBoot+Vue的二手电子产品交易平台二手数码产品交易平台的开发与实现【附源码、数据库、万字文档】
  • 重复率过了AI率却超?这五佳降AI工具能用
  • 通信原理篇---可靠性和有效性
  • Amaze File Manager:一款基于 Material Design 的开源安卓文件管理器
  • LLM解析脑电波,中风康复预测提前1月
  • 综合实践
  • 2025专科生必看!9大AI论文平台测评,写毕业论文还能这么快?
  • AI率怎么都降不下去?前五降AI工具真实体验
  • 靠谱的康有利到家理疗小程序公司
  • 【记录】2025 年终总结
  • Java毕设选题推荐:基于SpringBoot+Vue的具有推荐功能的二手交易基于SpringBoot+Vue的二手数码产品交易平台的开发与实现【附源码、mysql、文档、调试+代码讲解+全bao等】
  • Java毕设选题推荐:基于SpringBoot社区住户信息管理系统基于web的社区居民信息管理系统【附源码、mysql、文档、调试+代码讲解+全bao等】
  • Alpine.js:轻量级JavaScript框架完全入门指南
  • 网易云音乐ncm加密转mp3格式
  • Java特性和优势