当前位置:首页 > 数码 > Cloud-body-中读取-时的经常出现疑问-Spring-Gateway-彻底处置 (cloud-based)

Cloud-body-中读取-时的经常出现疑问-Spring-Gateway-彻底处置 (cloud-based)

admin1年前 (2024-04-29)数码101

在构建微服务架构时,SpringCloudGateway作为一个关键的微服务网关,经常须要在过滤器(Filter)中对POST恳求的Body内容启动操作,如日志记载、签名验证和权限验证等。但是,因为Request的Body只能读取一次性,假设间接在过滤器中读取而不启动封装,或者造成后续服务不可失掉数据。

网上搜这个疑问的处置打算,大少数文章都是通知你写一个Filter将Request的Body缓存起来。这种方法确实可以,只不过须要对代码经过充沛压力测试,否则很有或者产生如下所示的堆外内存溢出疑问。

reactorty.ReactorNetty$InternalNettyException:io.netty.util.internal.OutOfDirectMemoryError:fledtoallocate
Gateway

实践上,SpringCloudGateway曾经内置了AdaptCachedBodyGlobalFilter过滤器,它在Exchange中奇妙地缓存了Request的Body,防止了间接读取造成的一系列疑问。这种形式更为稳当,防止了潜在的内存溢出危险。

图片

在须要失掉Body的中央,咱们只有要经过以下方法即可:

DataBufferbody=exchange.getAttributeOrDefault("cachedRequestBody",null);StringbodyStr=body.toString(StandardCharsets.UTF_8);

只不过经过源码可以看出,缓存RequestBody须要路由被标志为须要缓存,也就是this.routesToCache.containsKey(rouceId)方法肯定前往true。

AdaptCachedBodyGlobalFilter会监听EnableBodyCachingEvent事情,当颁布该事情时就将RouteId放入routesToCache中。为了繁难经常使用,咱们可以编写一特性能类,在初始化时颁布EnableBodyCachingEvent事情,将一切路由都启用缓存性能。

@Configuration(proxyBeanMethods=false)@Slf4jpublicclassEnableCachedBodyConfiguration{@ResourceprivatelicationEventPublisherpublisher;@ResourceprivateGatewayPropertiesgatewayProperties;@PostConstructpublicvoidinit(){gatewayProperties.getRoutes().forEach(routeDefinition->{//对springcloudgateway路由性能中的每个路由都启用AdaptCachedBodyGlobalFilterEnableBodyCachingEventenableBodyCachingEvent=newEnableBodyCachingEvent(newObject(),routeDefinition.getId());publisher.publishEvent(enableBodyCachingEvent);});}}

经过这种形式,咱们可以愈加繁难地处置POST恳求的Body内容,防止了一些经常出现的疑问。在实践运行中,思考到稳固性和性能,这种处置打算提供了一种更为牢靠的选用。


springcloudgateway怎么故障转移

在SpringCloudGateway中实现故障转移通过以下步骤进行操作:1、配置服务注册和发现确保你的微服务已经注册到服务注册中心,例如Eureka或Consul。 这将使Gateway能够发现可用的服务实例。 2、配置负载均衡:在Gateway的路由配置中,使用负载均衡器来分发请求到多个服务实例。 SpringCloudGateway默认集成了Ribbon作为负载均衡器,你可以使用`LoadBalancerClient`来实现负载均衡。 3、配置熔断器:为了实现故障转移,你可以在Gateway中使用熔断器来处理故障的服务。 SpringCloudGateway集成了Resilience4j和Hystrix作为熔断器,默认使用Resilience4j。 你可以在路由配置中添加熔断器的相关配置,例如设置熔断器的阈值、超时时间等。 4、配置降级策略:如果某个服务发生故障,你可以在Gateway中配置降级策略,返回一个默认的响应或者转发到备用的服务。 你可以使用`fallbackUri`属性来指定降级的路由。 5、监控和告警:为了及时发现故障和进行故障转移,你可以使用监控和告警工具来监控Gateway和后端服务的状态。 SpringCloudGateway集成了SpringBootActuator,你可以通过Actuator来暴露监控和健康检查的端点。

springcloudgateway更新不及时

springcloudgateway更新不及时办法:1、gateway正常将/test/hello转发至服务A。 2、在nacos管理端让服务A下线。 3、立刻访问不停/test/hello。 4、最初几秒内发现gateway还是会把流量打到服务A。 5、之后正常响应。

免责声明:本文转载或采集自网络,版权归原作者所有。本网站刊发此文旨在传递更多信息,并不代表本网赞同其观点和对其真实性负责。如涉及版权、内容等问题,请联系本网,我们将在第一时间删除。同时,本网站不对所刊发内容的准确性、真实性、完整性、及时性、原创性等进行保证,请读者仅作参考,并请自行核实相关内容。对于因使用或依赖本文内容所产生的任何直接或间接损失,本网站不承担任何责任。

标签: Spring

“Cloud-body-中读取-时的经常出现疑问-Spring-Gateway-彻底处置 (cloud-based)” 的相关文章

如何在Spring名目中顺利性能MP-MyBatis (如何在springer上下载文献)

如何在Spring名目中顺利性能MP-MyBatis (如何在springer上下载文献)

在Spring名目中集成MP,须要启动以下性能: 1.引入依赖:在名目标pom.xml文件中参与MP相关依赖,例如:```xml<dependency><groupId&g...

Boot-Spring-与-3.0-加速应用性能的完美融合-GraalVM (bootstrap)

Boot-Spring-与-3.0-加速应用性能的完美融合-GraalVM (bootstrap)

在 2023 年,SpringBoot 3.0 的发布标志着 Spring 框架对 GraalVM 的全面支持。此支持对 Spring 技术栈来说是一项重大补充。 GraalVM 概述...

6-Spring-提供的四种弱小工具-远程接口调用神器 (6sp日常使用还能用多久)

6-Spring-提供的四种弱小工具-远程接口调用神器 (6sp日常使用还能用多久)

1.引见 Spring6是一个十分弱小的框架,它提供了许多工具和接口来简化远程接口调用。其中,WebClient、RestTemplate、HTTPInterface和RestClient是...

揭秘-的暗藏技艺-AOP-从概念到实用场景-Spring (神秘丂丂是什么意思)

揭秘-的暗藏技艺-AOP-从概念到实用场景-Spring (神秘丂丂是什么意思)

环境:Spring5.3.23 1.引见 当天看Spring文档看到这么一个常识点《ControlFlowPointcuts》都不好翻译 官网原文: Springcontr...

Spring-Boot-Starter原理详解-b-b (springernature)

Spring-Boot-Starter原理详解-b-b (springernature)

SpringBoot Starter 是一种包含了一组特定功能和依赖关系的依赖项,旨在为特定的应用程序场景提供快速集成和开箱即用的功能。主要用于将常用的功能模块打包成一个可重用的依赖项,开发者只需...

Boot中高效成功订单30分钟智能敞开的战略指南-Spring-源代码揭秘 (high boot)

Boot中高效成功订单30分钟智能敞开的战略指南-Spring-源代码揭秘 (high boot)

形式一:经常使用定时义务 代码成功如下: 首先,咱们定义一个实体类Order,蕴含基本信息以及订单的创立期间: @EntitypublicclassOrder{@Id@Generat...

使用Spring-Cloud和Java构建强大而灵活的微服务-十个实践案例 (使用spring框架的好处是什么)

使用Spring-Cloud和Java构建强大而灵活的微服务-十个实践案例 (使用spring框架的好处是什么)

在使用构建微服务时,许多人认为只要学习一些微服务设计模式就足够了,比如 CQRS、SAGA 或每个微服务一个数据库。虽然这是正确的,但同时学习一些通用的最佳实践也是很有意义的。本文分享一些最佳实践...

Scope及源码剖析-玩转Spring各种作用域Bean

Scope及源码剖析-玩转Spring各种作用域Bean

SpringScopeBean是Spring框架中用于治理Bean的作用域的机制,它定义了Bean的生命周期和实例化战略。经过正当地选用Bean的作用域,可以优化运行的性能和资源应用率。 环境:S...