解决Spring boot添加了actuator导致StreamBridge未自动加载的bug

案情说明

在Spring boot项目中,如果同时依赖了spring-cloud-starter-stream-rabbitspring-boot-start-actuator两个包,启动时可能会出现StreamBridge组件找不到的问题。如下:

shell 复制代码
***************************
APPLICATION FAILED TO START
***************************

Description:

Field bridge in com.venustech.electric.iops.alert.collector.job.writer.AnchorMapToStreamItemWriterBuilder required a bean of type 'org.springframework.cloud.stream.function.StreamBridge' that could not be found.

The injection point has the following annotations:
        - @org.springframework.beans.factory.annotation.Autowired(required=true)


Action:

Consider defining a bean of type 'org.springframework.cloud.stream.function.StreamBridge' in your configuration.

如果现象类似,着急的同学可以直接看解决方案。

初步分析

案发之前,这个服务是正常运行的,只是没有启用actuator。因此,又尝试将spring-boot-start-actuator依赖去除。果然就恢复正常了。可以断定是actuator与rabbit的包存在冲突

解决思路

一般遇到这种情况,首先是检查版本号是否冲突,根据Spring官网的说明,版本号一致的情况下,理论上不会有这种情况,如果有那就是BUG。

案发现场的环境是Spring Boot 2.7.13Spring Cloud 2021.0.8,这个两个版本号是符合官方要求的。那无疑是点背撞上BUG了。

之前也有过同时使用rabbit和actuator的成功案例,从未发生过类似事件。因此,尝试了从多种角度去解决问题,包括但不限于:

  • 升级到新版本。如果是小版本,还可以尝试,大版本升级,往往会导致其它更多的组件冲突问题,不能抱太大希望;
  • 把一些间接依赖改为直接依赖,如把spring-cloud-starter-stream-rabbit依赖的包都手动再依赖一次;
  • 在配置类中显示的启用类似@EnableRabbit的配置开关;
  • 问问人工智能,这两个冲突怎么办?结果这帮智障一个劲的告诉我,这不可能。。。

以上这些方式在本案中都没有办法解决问题。最终,参考了CSDN上的一篇文章找到了答案:《记录一次streamBridge could not be found的问题》

这里也要给该文章的作者点个赞,他解决问题的思路非常清晰。

确认问题原因

这个问题根本原因是SimpleFunctionRegistry类由于在运行时对应的开关配置没有开启,导致没有被正确加载。

最终的解决方案

启用打开spring.functional.enabled配置。

Properties写法:

properties 复制代码
spring.functional.enabled=true

yml写法:

ymal 复制代码
spring:
	functional:
		enabled: true

鸣谢

再次感谢《记录一次streamBridge could not be found的问题》的作者C'est

相关推荐
一个松1 天前
【无标题】
spring boot
小wanga1 天前
C++知识
java·开发语言·c++
我是渣哥1 天前
Java String vs StringBuilder vs StringBuffer:一个性能优化的探险故事
java·开发语言·jvm·后端·算法·职场和发展·性能优化
工一木子1 天前
深入Java并发:锁机制原理剖析与性能优化实战
java·性能优化·并发·
你我约定有三1 天前
java--写在 try 中的创建连接
java·开发语言
ERP老兵-冷溪虎山1 天前
Python/JS/Go/Java同步学习(第三篇)四语言“切片“对照表: 财务“小南“纸切片术切凭证到崩溃(附源码/截图/参数表/避坑指南/老板沉默术)
java·javascript·python·golang·中医编程·四语言同步学习·职场生存指南
科技树支点1 天前
无GC的Java创新设计思路:作用域引用式自动内存管理
java·python·go·web·编程语言·编译器
码农小伙1 天前
ConcurrentHashMap解析
java·开发语言
WhiteJunior1 天前
Java基础知识点汇总(五)
java·开发语言
晚安里1 天前
JVM相关 4|JVM调优与常见参数(如 -Xms、-Xmx、-XX:+PrintGCDetails) 的必会知识点汇总
java·开发语言·jvm·后端·算法