Spring Cloud GateWay 引入 Feign Reactive 踩坑记录

问题1: 项目启动报错:Invalid value type for attribute 'factoryBeanObjectType': java.lang.String

问题2: Bean冲突

起因

Spring Gateway 模型为WebFlux ,使用的是Netty 容器,属于异步非阻塞模型

OpenFeign 所使用的是于同步阻塞模型

因而二者存在模型不兼容 ,存在线程饥饿现象

引入Reactive-Feign来解决模型问题

官方对于响应式模型说明: Spring Cloud OpenFeign文档

其中1.19 明确指示当前版本的OpenFeign不支持响应式,鼓励用户使用第三方社区的增强版Feign-Reactive

简介: Feign Reactive 是一种基于响应式编程的远程服务调用框架,是 Spring Cloud 项目中的一部分。它提供了一种声明式的、基于注解的方式来定义和实现远程服务接口,同时支持响应式编程模型。 与传统的 Feign 不同,Feign Reactive 对响应式编程的支持使得它更适合于处理异步和流式的数据。它与 Spring WebFlux 集成,支持使用 Reactor、RxJava 等响应式库进行开发。

1.项目pom中引入

xml 复制代码
<!-- https://mvnrepository.com/artifact/com.playtika.reactivefeign/feign-reactor-spring-cloud-starter -->
<dependency>
    <groupId>com.playtika.reactivefeign</groupId>
    <artifactId>feign-reactor-spring-cloud-starter</artifactId>
    <version>4.0.3</version>
    <type>pom</type>
</dependency>

2.启动项开启响应式Feign

添加注解@EnableReactiveFeignClients

3.随意编写一个测试用的Client

通过注解@ReactiveFeignClient开启

此时启动项目就会出现

问题1 : 项目启动报错:Invalid value type for attribute 'factoryBeanObjectType': java.lang.String需要提供该Bean返回的类型,显然该Bean返回的并不是一个String,故而报错

进而导致报以下错,致使整个项目无法启动 org.springframework.boot.autoconfigure.context.PropertyPlaceholderAutoConfiguration.propertySourcesPlaceholderConfigurer

原因分析: 错误在源码中,无法通过常规方式修复

1.org.springframework.beans.factory.support包下的FactoryBeanRegistrySupport类中getTypeForFactoryBeanFromAttributes方法中明确指示factoryBeanObjectType为String而不是一个类

2.reactivefeign.spring.config包的ReactiveFeignClientsRegistrar类的registerReactiveFeignClient方法中的beanDefinition.setAttribute(FactoryBean.OBJECT_TYPE_ATTRIBUTE, className);这一行代码中明确指示了一个K-V 关系 FactoryBean.OBJECT_TYPE_ATTRIBUTE : className

启动的时候报错: attribute不能为String,在这段KV关系中,Feign-Reactive清楚地attreibute 对应的value设置为了一个String类型

解决方案(需要改动源代码,先说解决方案,再讲怎么改源码)

综上:需要放入一个Clazz而非String,所以只要把className对应的Class 拿出来替代className就好了

再次启动发现不再报该错误,但是紧接着 问题2: Bean冲突 出现了

txt 复制代码
Parameter 1 of method reactiveFeignContract in reactivefeign.spring.config.ReactiveFeignClientsConfiguration required a single bean, but 2 were found:
	- feignConversionService: a programmatically registered singleton
	- webFluxConversionService: defined by method 'webFluxConversionService' in class path resource [org/springframework/boot/autoconfigure/web/reactive/WebFluxAutoConfiguration$EnableWebFluxConfiguration.class]

由错误信息可知,在feignConversionServicewebFluxConversionService这两个Bean中,返回的都是同样对象类型 只需要在其中一个Bean中添加@Primary即可解决,推荐在feignConversionService中添加。因为feignConversionService问题1所在的类为同一个

自此重新启动项目即可恢复正常

疑惑1: 问题怎么发现的

经历了问ChatGpt,翻遍CSDN和掘金以及博客园,全部无果 。我去GitHub翻了Issue看到的解答。国内完全没有相关资料,更没有人记录。

GitHub Issue 解答

疑惑2: 怎么修改源码 根据疑惑1的大佬解惑,方式是: 打patch补丁。但是比较麻烦,所以我用了一个更麻烦的笨方法,但是可能简单一点

第一步. 下载官方的源码 github.com/PlaytikaOSS...

第二步. 用IDE打开官方项目

第三步. 修改相关代码

第四步. 修改结束后install到本地仓库,上述的修改都在模块feign-reactor-spring-configuration 里,只需要install这个模块就好了

注: 官方GitHub仓库地址 github.com/PlaytikaOSS...

至此已经结束

后话

1.由于GitHub被墙,下载慢,我直接使用Gitee将其整个项目拉取。如果不想根据疑惑2 的方式修改,直接访问我的Gitee gitee.com/jaluson/fei... 拉取项目,然后执行第四步就好.

2.此短文目的: 由于相关问题没有明确的解答,故而在此,仅作为自己的学习记录,方便自己后续温习。

相关推荐
源码121517 分钟前
ASP.NET MVC宠物商城系统
后端·asp.net·宠物
Ai 编码助手1 小时前
Go语言 实现将中文转化为拼音
开发语言·后端·golang
hummhumm1 小时前
第 12 章 - Go语言 方法
java·开发语言·javascript·后端·python·sql·golang
杜杜的man1 小时前
【go从零单排】Directories、Temporary Files and Directories目录和临时目录、临时文件
开发语言·后端·golang
wywcool2 小时前
JVM学习之路(5)垃圾回收
java·jvm·后端·学习
喜欢打篮球的普通人2 小时前
rust高级特征
开发语言·后端·rust
代码小鑫3 小时前
A032-基于Spring Boot的健康医院门诊在线挂号系统
java·开发语言·spring boot·后端·spring·毕业设计
豌豆花下猫4 小时前
REST API 已经 25 岁了:它是如何形成的,将来可能会怎样?
后端·python·ai
喔喔咿哈哈4 小时前
【手撕 Spring】 -- Bean 的创建以及获取
java·后端·spring·面试·开源·github
夏微凉.4 小时前
【JavaEE进阶】Spring AOP 原理
java·spring boot·后端·spring·java-ee·maven