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

相关推荐
m0_740043731 天前
【无标题】
java·spring boot·spring·spring cloud·微服务
Gary董1 天前
高并发的微服务架构如何设计
微服务·云原生·架构
像少年啦飞驰点、1 天前
零基础入门 Spring Boot:从“Hello World”到可部署微服务的完整学习路径
java·spring boot·微服务·编程入门·后端开发
java干货1 天前
微服务:把一个简单的问题,拆成 100 个网络问题
网络·微服务·架构
indexsunny1 天前
互联网大厂Java求职面试实战:Spring Boot微服务与Kafka消息队列应用解析
java·数据库·spring boot·微服务·面试·kafka·jpa
天才奇男子2 天前
《深度解析HAProxy七层代理:原理、配置与最佳实践》
linux·运维·微服务·云原生
onkel in blog2 天前
【Java】Gradle 多模块项目实战:Spring Boot 微服务搭建全流程
java·spring boot·微服务·gradle
七夜zippoe2 天前
Kubernetes与Python微服务编排实战:从基础部署到自动扩缩容
python·微服务·kubernetes·service·hpa
小楼v2 天前
使用Nacos实现动态IP黑名单过滤
java·后端·微服务·nacos
JavaLearnerZGQ2 天前
Gateway网关将登录用户信息传递给下游微服务(完整实现方案)
微服务·架构·gateway