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>本地配置

相关推荐
A.说学逗唱的Coke13 小时前
【观察者模式】深入 Spring 事件驱动模型:从入门到微服务整合实战
spring·观察者模式·微服务
论迹19 小时前
【Spring Cloud 微服务】-- 服务拆分原则
java·spring cloud·微服务
阿里云云原生1 天前
阿里云微服务引擎 MSE 及 API 网关 2025 年 10 月产品动态
阿里云·微服务·云原生·云计算
Tadas-Gao2 天前
MySQL存储架构解析:从数据无序到索引艺术的演进
数据库·分布式·mysql·微服务·云原生·架构
CV_J2 天前
编写微服务api
微服务·云原生·架构
黄暄2 天前
微服务面试题(14题)
java·spring cloud·微服务·架构·java-rabbitmq·java-zookeeper
忙碌5442 天前
智能应用开发指南:深度学习、大数据与微服务的融合之道
大数据·深度学习·微服务
小冯的编程学习之路2 天前
【C++】:C++基于微服务的即时通讯系统(2)
开发语言·c++·微服务
IT小哥哥呀2 天前
Jenkins + Docker 打造自动化持续部署流水线
docker·微服务·自动化·jenkins·springboot·高并发·限流
虾米Life2 天前
基于微服务脚手架的视频点播系统 (仿B站) [客户端] -1
c++·qt·微服务·架构