Duplicate spring bean id 问题调查

Posted 修行者HT

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Duplicate spring bean id 问题调查相关的知识,希望对你有一定的参考价值。

问题背景:从本地调用服务器的dubbo接口进行测试

实现思路:基于IDEA+Spring+maven+Dubbo搭建测试项目,从本地直接调用

       具体实现思路可参考博客:https://www.cnblogs.com/xiuxingzhe/p/9250737.html

碰到问题:引入测试目标jar后,调用其接口运行测试类时,报错如下

Caused by: java.lang.IllegalStateException: Duplicate spring bean id cfgDistributorServiceImpl
    at com.alibaba.dubbo.config.spring.schema.DubboBeanDefinitionParser.parse(DubboBeanDefinitionParser.java:106)
    at com.alibaba.dubbo.config.spring.schema.DubboBeanDefinitionParser.parse(DubboBeanDefinitionParser.java:77)
    at org.springframework.beans.factory.xml.NamespaceHandlerSupport.parse(NamespaceHandlerSupport.java:74)
    at org.springframework.beans.factory.xml.BeanDefinitionParserDelegate.parseCustomElement(BeanDefinitionParserDelegate.java:1411)
    at org.springframework.beans.factory.xml.BeanDefinitionParserDelegate.parseCustomElement(BeanDefinitionParserDelegate.java:1401)
    at org.springframework.beans.factory.xml.DefaultBeanDefinitionDocumentReader.parseBeanDefinitions(DefaultBeanDefinitionDocumentReader.java:168)
    at org.springframework.beans.factory.xml.DefaultBeanDefinitionDocumentReader.doRegisterBeanDefinitions(DefaultBeanDefinitionDocumentReader.java:138)
    at org.springframework.beans.factory.xml.DefaultBeanDefinitionDocumentReader.registerBeanDefinitions(DefaultBeanDefinitionDocumentReader.java:94)
    at org.springframework.beans.factory.xml.XmlBeanDefinitionReader.registerBeanDefinitions(XmlBeanDefinitionReader.java:508)
    at org.springframework.beans.factory.xml.XmlBeanDefinitionReader.doLoadBeanDefinitions(XmlBeanDefinitionReader.java:392)  

调查思路

    1.检查项目中spring是否加载了两个一样的配置文件或者相同的dubbo配置

      spring对于id的重复,默认的处理策略是覆盖

      但是dubbo的新版本对重复的id做了特殊处理,如果本地创建了一个bean,然后又去注册中心拿到相同的bean,就会重复直接抛异常

      检查结果:自己的测试项目中并没有重复加载配置文件或者存在相同的dubbo配置

    

    2.spring扫描项目时,不仅会扫描当前项目中dubbo消费者,新建的类等需要注册的bean

     还会扫描pom.xml中引入的jar包中的带有以下注解的类:@Component,@Repository,@Service,@Controller,@RestController,@ControllerAdvice, @Configuration

     所以在引入包的时候,不能引入service包,因为service层的类多包含有注解@service,需要引入的是facade接口层的jar包

 

        检查了一下,自己引入的就是service层的jar包,至此问题找到了

     <dependency>
            <groupId>com.msa.base</groupId>
            <artifactId>base-service</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>

     修改成facade层的引入

     <dependency>
            <groupId>com.msa.base</groupId>
            <artifactId>base-service-facade</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>

      重跑测试类:调用成功

 

 

  

以上是关于Duplicate spring bean id 问题调查的主要内容,如果未能解决你的问题,请参考以下文章

spring的bean的id要怎么理解呢?

spring 中bean的id必须要和实现类的大小写一致吗

为啥spring不同配置中可以存在相同的id的bean

Spring---bean的命名

Spring bean的生命周期详解

Spring讲解二:Spring中的Bean配置1---基于XML文件的方式