Dubbo 2.6.2 获取不到${dubbo.registry.address}

背景

公司原来的配置中心是一个闭源的系统,该系统有几个痛点问题:无权限控制、敏感配置不能加密、应用和配置的依赖关系混乱。
在这个背景下,运维同学基于k8s的configMap写了一个配置中心,并推动应用配置从闭源的配置中心迁移到自有的configMap。

获取dubbo.registry.address配置项

因为我负责这次迁移,所以迁移过程中开发同学碰到的问题都会来问我,其中有一个比较有意思的问题是dubbo 获取不到dubbo.registry.address配置项。比如明明在application.properties配置文件中配置了该配置项 dubbo.registry.address=zk-0:2181,但应用启动时就是获取不到;

源码

此类问题排查思路也比较直接:直接看源码!

通过debug,很快定位到dubbo.registry.address是在AbstractInterfaceConfig.java 第188行获取配置的。

获取配置

突然发现有点不太对劲,怎么获取配置的这个方式是静态方案?!难道没有和spring的PropertySource打通?

点进去该方法果然发现,这里的配置并不是从spring的PropertySource中获取的,而是尝试从系统环境变量中获取,获取不到再从配置的文件中获取。参考com.alibaba.dubbo.common.utils.ConfigUtils#getProperty(java.lang.String, java.lang.String)

获取配置

这时候真相大白了,人家压根就没有去application.properties中获取,那肯定就拿不到了。

后面想看看dubbo对这个问题进行处理,于是乎打开了2.7.6版本的源码瞅了瞅。在这个版本中,dubbo变成了从spring中获取配置的方式。感兴趣的小伙伴可以看看相关的源码,这里就不展开了。

从Spring PropertySource中获取

解法

  1. 手动配置一个RegistryConfig Spring Bean;
  2. 将dubbo相关配置设置到系统环境变量中;
  3. 升级到2.7.6。

你可能感兴趣的:(Dubbo 2.6.2 获取不到${dubbo.registry.address})