前言
SpringBoot项目使用nacos作为配置中心和服务注册中心,同时兼容dubbo的注册中心。
本Demo项目使用的SpringBoot版本是2.3.9.RELEASE。
项目中没有使用nacos官方提供的方式使用SpringBoot的集成方式来进行集成,而是使用了Alibaba Spring Cloud的依赖包进行集成。
原因是因为官网提供的SpringBoot集成方式中,同时使用配置中心和服务发现功能,会使得服务发现功能配置的部分属性冲突不生效。最直接的就是配置中心和服务发现功能不可以配置2个不同的namespace,会默认选择使用配置中心中配置的namespace作为服务发现的namespace。
另外一点就是可以很好的和Spring的注解兼容,无需额外的注解。例如@NacosValue注解。
maven依赖
1 | <dependency> |
Nacos配置中心
配置文件
新建bootstrap.properties文件,在配置文件中配置nacos的配置信息。
1 | # ============== nacos-config ============== # |
注意:由于spring cloud alibaba nacos config的加载机制问题,配置信息如果写在了application-{env}.properties的配置文件中无法被解析。所以如果需要分多环境动态加载,可以写在bootstrap-{env}.properties文件中。
启动的时候配置active profiles+ 环境就可以正确读取配置了
动态配置
新建配置
在名为config-dev的namespace中新建配置demeter-application-admin。
配置中的data-id就不再多说了,这个可以查看资料,网上有很多资料进行了详细描述。
data-id参考如下:
- demeter-application-admin
- demeter-application-admin.properties
- demeter-application-admin-dev.properties
配置实体类
DemeterAdminProperties.class
1 |
|
使配置生效。@EnableConfigurationProperties注解使DemeterAdminProperties可以被实例化,自动注入到其他组件中。
1 | @Configuration |
访问结果
Controller
结果
Nacos服务发现
配置文件
1 | # ============== nacos-discovery ============== # |
使配置生效
使用@EnableDiscoveryClient注解使配置文件能够生效.





