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>

      重跑測試類:調用成功

 

 

  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM