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

相关推荐
小小爱19909 小时前
微服务学习笔记
微服务
agenIT11 小时前
micro-app前端微服务原理解析
前端·微服务·架构
我的golang之路果然有问题14 小时前
快速了解Go+微服务(概念和一个例子)
开发语言·笔记·后端·学习·微服务·golang
素雪风华14 小时前
服务容错治理框架resilience4j&sentinel基础应用---微服务的限流/熔断/降级解决方案
java·微服务·sentinel·springboot·服务容错·resilience
南客先生15 小时前
音视频项目在微服务领域的趋势场景题深度解析
java·微服务·面试·性能优化·音视频·高并发
angushine16 小时前
SpringBoot多工程项目微服务install时如何不安装到本地仓库
spring boot·后端·微服务
南客先生17 小时前
SpringBoot、微服务与AI场景题深度解析
微服务·面试·springboot·ai技术
南客先生21 小时前
金融行业微服务架构设计与挑战 - Java架构师面试实战
java·微服务·高并发·分布式事务·数据一致性·金融行业
科技万象1 天前
SpringBoot终极形态:AI生成带OAuth2鉴权的微服务模块(节省20人日)
人工智能·spring boot·微服务
沛沛老爹1 天前
企业架构之旅(3):TOGAF ADM架构愿景的核心价值
微服务·架构·架构愿景