news 2026/5/17 5:14:19

解决FeignClient Bean名称重复注册:The bean ‘xxx.FeignClientSpecification‘已定义且覆盖禁用

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
解决FeignClient Bean名称重复注册:The bean ‘xxx.FeignClientSpecification‘已定义且覆盖禁用

近期在启动项目时遇到了一个典型的报错:The bean 'contract-management-service.FeignClientSpecification' could not be registered. A bean with that name has already been defined and overriding is disabled.,这个报错直接导致服务启动失败,排查后发现是FeignClient配置的常见疏漏,本文将详细还原问题场景、分析根源,并给出可直接落地的解决方案,帮助快速定位和解决此类问题。

核心内容展开

场景复现(含报错信息、环境配置)

环境配置
  • Spring Boot版本:2.6.8
  • Spring Cloud版本:2021.0.3
  • Spring Cloud OpenFeign版本:3.1.3
问题现象

项目启动时控制台抛出如下异常,服务启动失败:

org.springframework.beans.factory.support.BeanDefinitionOverrideException: The bean 'contract-management-service.FeignClientSpecification' could not be registered. A bean with that name has already been defined and overriding is disabled.

查看项目中的FeignClient接口,发现存在两个及以上使用相同name/value属性的@FeignClient注解,示例如下:

// 第一个FeignClient接口@FeignClient(name="contract-management-service")publicinterfaceContractInfoFeignClient{@GetMapping("/contract/info/{id}")StringgetContractInfo(@PathVariable("id")Longid);}// 第二个FeignClient接口@FeignClient(name="contract-management-service")publicinterfaceContractAuditFeignClient{@PostMapping("/contract/audit")BooleanauditContract(@RequestBodyContractAuditDTOdto);}

问题根源分析

Feign在初始化时,会为每个@FeignClient注解生成对应的FeignClientSpecificationBean,该Bean的名称默认由@FeignClientname/value属性拼接固定后缀生成(格式为:{name}.FeignClientSpecification)。

Spring容器中Bean的名称是唯一的,当多个@FeignClient使用相同的name/value且未做额外区分时,会生成同名的FeignClientSpecificationBean。而Spring Boot 2.1+版本默认禁用了Bean覆盖(spring.main.allow-bean-definition-overriding=false),因此容器检测到同名Bean时会直接抛出注册异常,导致服务启动失败。

简单来说,核心问题是:相同name/value的@FeignClient未指定contextId,导致生成的FeignClientSpecification Bean名称重复,且Bean覆盖机制禁用

解决方案

步骤1:指定唯一名称

为每个使用相同name/value的@FeignClient指定唯一的contextId属性,Feign会基于contextId生成唯一的FeignClientSpecificationBean名称,避免重复。

步骤2:修改FeignClient接口配置

为每个重复name的FeignClient补充contextId属性,示例如下:

// 第一个FeignClient接口:指定contextId为contractInfoClient@FeignClient(name="contract-management-service",contextId="contractInfoClient")publicinterfaceContractInfoFeignClient{@GetMapping("/contract/info/{id}")StringgetContractInfo(@PathVariable("id")Longid);}// 第二个FeignClient接口:指定contextId为contractAuditClient@FeignClient(name="contract-management-service",contextId="contractAuditClient")publicinterfaceContractAuditFeignClient{@PostMapping("/contract/audit")BooleanauditContract(@RequestBodyContractAuditDTOdto);}

验证结果

修改完成后,重新启动项目,控制台不再抛出Bean名称重复的异常,服务正常启动。通过访问FeignClient对应的接口,验证远程调用功能正常,无异常。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/11 15:41:03

如何快速将PSD导入Unity:免费高效的终极解决方案指南

如何快速将PSD导入Unity:免费高效的终极解决方案指南 【免费下载链接】UnityPsdImporter Advanced PSD importer for Unity3D 项目地址: https://gitcode.com/gh_mirrors/un/UnityPsdImporter UnityPsdImporter是一款专为Unity3D开发者设计的高级PSD导入工具…

作者头像 李华
网站建设 2026/5/12 13:04:39

AgentWeb终极迁移指南:5步告别版本升级困扰

AgentWeb终极迁移指南:5步告别版本升级困扰 【免费下载链接】AgentWeb AgentWeb is a powerful library based on Android WebView. 项目地址: https://gitcode.com/gh_mirrors/ag/AgentWeb AgentWeb作为基于Android WebView的强大库,在版本升级…

作者头像 李华
网站建设 2026/5/9 21:36:38

基于大数据的青少年精准普法教育系统设计大纲修改

目录摘要绪论研究目标研究意义现实意义理论意义国内外研究现状国外研究现状国内研究现状可行性分析精准普法教育需求分析基本概念普法教育系统设计相关理论国内外青少年法治宣传教育现状国内外普法教育的发展历程当前普法教育的成效与不足大数据与精准普法的关系大数据技术在普…

作者头像 李华
网站建设 2026/5/16 21:18:49

BotW存档管理器:跨平台游戏进度无缝迁移解决方案

BotW存档管理器:跨平台游戏进度无缝迁移解决方案 【免费下载链接】BotW-Save-Manager BOTW Save Manager for Switch and Wii U 项目地址: https://gitcode.com/gh_mirrors/bo/BotW-Save-Manager 在《塞尔达传说:旷野之息》的冒险旅程中&#xff…

作者头像 李华
网站建设 2026/5/15 11:45:14

HumanML3D实战宝典:从入门到精通的10个核心技巧

HumanML3D实战宝典:从入门到精通的10个核心技巧 【免费下载链接】HumanML3D HumanML3D: A large and diverse 3d human motion-language dataset. 项目地址: https://gitcode.com/gh_mirrors/hu/HumanML3D 在当今人工智能快速发展的时代,3D运动数…

作者头像 李华
网站建设 2026/5/14 16:04:15

MacBook Pro上的AI图像放大终极指南:Upscayl性能优化全解析

MacBook Pro上的AI图像放大终极指南:Upscayl性能优化全解析 【免费下载链接】upscayl 🆙 Upscayl - Free and Open Source AI Image Upscaler for Linux, MacOS and Windows built with Linux-First philosophy. 项目地址: https://gitcode.com/GitHub…

作者头像 李华