在一个项目中,如果有多个FeignClient客户端指向同一个微服务,项目启动的过程中可能会抛出如下的异常The bean 'xxx.FeignClientSpecification' could not be registered. A bean with that name has already been defined and overriding is disabled.
。
具体异常如下:
解决方法
方法一
按照异常的提示在配置文件中添加如下配置:
方法二
在@FeignClient注解里面添加contextId属性,并保证两个客户端中的contextId属性不一致:
从源码分析原因
@EnableFeignClients注解
在项目的启动类上有一个@EnableFeignClients
注解:
FeignClientsRegistrar类
FeignClientsRegistrar类会在项目启动过程中注入一些BeanDefinition:
registerFeignClients()
registerFeignClients()通过扫描带有@FeignClient
注解的类,为每个带有@FeignClient
注解的类向Spring容器中注入两个BeanDefinition:
- FeignClientSpecification
- FeignClientFactoryBean
getClientName()
FeignClientSpecification在Spring容器中beanName通过注解中的属性来决定:
FeignClientSpecification的beanName默认是使用为contextId.FeignClientSpecification
,如果contextId
属性不指定,就会使用value.FeignClientSpecification
。
通过源码分析,我们可以发现,当多个Feign客户端指向同一个服务时,如果不指定contextId,这些客户端在注册过程中可能会因为获取到相同的className而导致冲突,从而引发注册失败的问题。
因此,在配置多个指向相同服务的Feign客户端时,正确设置contextId是至关重要的,以确保每个客户端都能被Spring框架唯一地识别和注册。