28 nacos多环境配置共享

1.3.配置共享

其实微服务启动时,会去nacos读取多个配置文件,例如:

  • [spring.application.name]-[spring.profiles.active].yaml,例如:userservice-dev.yaml

  • [spring.application.name].yaml,例如:userservice.yaml

[spring.application.name].yaml不包含环境,因此可以被多个环境共享。

下面我们通过案例来测试配置共享

1)添加一个环境共享配置

我们在nacos中添加一个userservice.yaml文件:

2)在user-service中读取共享配置

在user-service服务中,修改PatternProperties类,读取新添加的属性:

java 复制代码
pattern:
  envSharedValue: 环境共享属性值

在user-service服务中,修改UserController,添加一个方法:

java 复制代码
    @Autowired
    private PatternProperties properties;

    @GetMapping("prop")
    public PatternProperties properties(){
        return properties;
    }

3)运行两个UserApplication,使用不同的profile

修改UserApplication2这个启动项,改变其profile值:

java 复制代码
test

UserApplication(8081)使用的profile是dev,UserApplication2(8082)使用的profile是test。

启动UserApplication和UserApplication2

访问http://localhost:8081/user/prop,

访问http://localhost:8082/user/prop,

可以看出来,不管是dev,还是test环境,都读取到了envSharedValue这个属性的值。

4)配置共享的优先级

当nacos、服务本地同时出现相同属性时,优先级有高低之分:

服务器profile.yaml>服务器名称.yaml>本地配置

相关推荐
阿里云云原生1 小时前
HiMarket 正式开源,为企业落地开箱即用的 AI 开放平台
微服务
眠りたいです5 小时前
基于脚手架微服务的视频点播系统-数据管理与网络通信部分的预备工作
c++·qt·ui·微服务·云原生·架构·媒体
码农小伙11 小时前
单体到微服务拆分方案
微服务·架构
mask哥1 天前
详解mcp以及agen架构设计与实现
java·微服务·flink·大模型·ai agent·springai·mcp
好多171 天前
《微服务事务管理》
java·微服务·架构
hzzzzzo01 天前
微服务保护全攻略:从雪崩到 Sentinel 实战
数据库·微服务·sentinel
APItesterCris2 天前
构建分布式京东商品数据采集系统:基于 API 的微服务实现方案
分布式·微服务·架构
hzzzzzo02 天前
微服务网关全解析:从入门到实践
java·开发语言·微服务
Angelyb2 天前
微服务保护和分布式事务
java·微服务·架构
鼠鼠我捏,要死了捏2 天前
蓝绿发布与滚动更新:基于Kubernetes的微服务零停机切换实战指南
微服务·kubernetes·blue-green