dubboDuplicate consumer configs或Duplicate providerconfigs问题解决

    技术2022-07-10  119

    新项目中使用了2.7.3 的版本

    报错如下

    Caused by: java.lang.IllegalStateException: Duplicate provider configs: <dubbo:provider timeout="3000" retries="0" filter="providerTraceFilter" dynamic="true" version="1.0.0" register="true" group="zybprod" deprecated="false" id="org.apache.dubbo.config.ProviderConfig" prefix="dubbo.provider" valid="true" /> and <dubbo:provider path="dev1" contextpath="dev1" dynamic="true" register="true" deprecated="false" prefix="dubbo.provider" valid="true" /> at org.apache.dubbo.config.spring.ServiceBean.afterPropertiesSet(ServiceBean.java:141) at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1855) at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1792) ... 65 common frames omitted

    分析原因: 其实Duplicate provider configs 提示的很明确了,关键是要找出重复的配置在哪里

    xml中有一个provider的配置 <dubbo:provider filter="providerTraceFilter" version="1.0.0" group="group11" retries="0" timeout="3000"/> 由于项目是springboot启动的,加了@EnableDubbo(scanBasePackages = "com.XX.XXX") EnableDubbo 的注解如下,其中包含了@EnableDubboConfig自动配置,当在application.properties 中或系统参数中配置了dubbo的配置时就会生成dubbo对应的配置 @Target({ElementType.TYPE}) @Retention(RetentionPolicy.RUNTIME) @Inherited @Documented @EnableDubboConfig @DubboComponentScan public @interface EnableDubbo {

    我是开发时配置启动参数,所以会有个一个provider的配置

    这样项目中就有两个dubbo provider的配置,找到重复的点就好解决了。 将xml中的配置删除掉,在application.properties文件中进行配置provider

    dubbo.provider.filter=providerTraceFilter dubbo.provider.version=1.0.0 dubbo.provider.group=group11 dubbo.provider.retries=0 dubbo.provider.timeout=3000

    这样即使vm 选项中配置了-Ddubbo.provider.path=dev1 启动也不会报配置重复的问题了

    Processed: 0.012, SQL: 9