美文网首页
Duplicate spring bean id 问题调查

Duplicate spring bean id 问题调查

作者: 修行者HT | 来源:发表于2019-07-15 16:26 被阅读0次

    问题背景:从本地调用服务器的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是否加载了两个一样的配置文件

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

          但是dubbo的新版本对重复的id做了特殊处理,如果有重复直接抛异常,就会出现上述问题

          检查结果:自己的项目中并没有重复加载配置文件

        

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

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

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

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

        

                com.msa.base

                base-service

                1.0-SNAPSHOT

    修改成facade层的引入

        

                com.msa.base

                base-service-facade

                1.0-SNAPSHOT

          重跑测试类:调用成功

    相关文章

      网友评论

          本文标题:Duplicate spring bean id 问题调查

          本文链接:https://www.haomeiwen.com/subject/vlvmmftx.html