新项目中使用了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 启动也不会报配置重复的问题了