05-详解Nacos配置管理中心,配置拉取的方式,热更新,配置共享(优先级)的步骤

Nacos配置管理

新建配置文件

当微服务部署的实例越来越多时,如果需要修改微服务的配置就需要逐个修改配置文件并且还要重启关联的微服务十分繁琐还易出错

项目中的配置文件分为每个项目特有的配置,项目所公用的配置

  • 每个项目特有的配置: 有些项目中需要但有些项目中又不需要的配置,或者在每个项目中配置的值不同的配置

    • 比如spring.application.name每个项目都需要配置但值不一样
    • 有些项目需要连接数据库/消息队列而有些项目不需要,有些项目需要配置消息队列而有些项目不需要
  • 项目所公用的配置: 在若干项目中配置内容相同的配置,比如很多项目一般用的是同一套的Redis服务的配置

Nacos除了可以做注册中心同样还可以集中管理所有服务实例的配置

  • 热更新: 在配置变更时及时通知微服务实例实现配置的热更新,即不需要重启服务实例修改后的配置就可以立即生效
  • 只有运行时需要调整配置属性值的配置才有被Nacos管理的必要,基本不会变更的一些配置还是保存到微服务本地如数据库连接配置

在Nacos的配置管理中添加配置文件: 配置列表->点击右侧加号->填写表单中的配置信息

在这里插入图片描述

配置拉取

引入方式

引入配置文件的形式有三种形式: 以服务名称方式引入,以扩展配置文件(extension-configs)方式引入,以共享配置文件(shared-configs)方式引入

  • 各配置文件的优先级: 本地bootstrap.yaml文件 > 服务名-环境名.yaml > 服务名.yaml > 扩展的远程配置文件 > 共享的远程配置文件 > 本地application.yaml文件

Spring引入了一种新的配置文件bootstrap.yml(只有配置到本地才能确定Nacos地址和配置文件Id)引导文件,读取的优先级高于application.yml文件

在这里插入图片描述

服务配置文件

第一步: 在user-service模块的pom文件中引入Nacos配置管理依赖spring-cloud-starter-alibaba-nacos-config

<!--nacos配置管理依赖-->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>

第二步: 在user-service模块的类路径下添加bootstrap.yml文件,通过NameSpace,Group,DataId(含应用名,环境,格式)定位Nacos服务端的远程配置文件

  • user-service(应用名): 通过spring.application.name指定
  • dev(环境名): 通过spring.profiles.active指定
  • Yaml(文件格式): 通过spring.cloud.nacos.config.file-extension指定,目前Nacos支持properties、yaml等格式的文件
# 以下这部分配置必须配置到本地
spring:
  application:
    name: user-service # 服务名称(与Nacos远程配置文件的名称一致)
  profiles:
    active: dev # 开发环境
  cloud:
    nacos:
      server-addr: localhost:8848 # Nacos服务端的地址
      config:
        file-extension: yaml # 文件后缀名

如果服务对应的远程配置文件不在默认的命名空间(public)和默认分组下,还需要在bootstrap.yaml中增加namespace和group属性配置命名空间和分组

在这里插入图片描述

spring:
  application:
    name: user-service # 服务名称(要与Nacos配置文件的名称一致)
  profiles:
    active: dev # 开发环境
  cloud:
    nacos:
      server-addr: localhost:8848 # Nacos地址
      config:
      	namespace: xxxxxxx # 远程配置文件所在的命名空间名称或ID
      	group: xxxx # 远程配置文件所在的分组
        file-extension: yaml # 远程配置文件的后缀名

第三步: 在user-service模块的UserController中读取对应远程配置文件中的配置,打开浏览器访问http://localhost:8081/user/now查看服务器响应的日期格式

  • @NacosValue注解或@Value注解: 注入Nacos管理的远程配置文件中的属性
@RestController
@RequestMapping("/user")
public class UserController {
    // 注入Nacos中的配置属性  
    //@NacosValue("${pattern.dateformat}")
    @Value("${pattern.dateformat}")
    private String dateformat;
	
    // 编写controller,通过日期格式化器来格式化现在时间并返回
    @GetMapping("/now")
    public String test() {
        return LocalDateTime.now().format(DateTimeFormatter.ofPattern(dateformat));
    }
}

扩展配置文件

实际开发中一个微服务模块可能依赖其他模块的配置文件,此时我们就需要使用extension-configs属性引入一个或多个配置文件

#微服务配置
spring:
  application:
    name: content-api
  cloud:
    nacos:
      server-addr: 127.0.0.1:8848
      discovery:
        namespace: ${spring.profiles.active}
        group: xuecheng-plus-project
      config:
        namespace: ${spring.profiles.active}
        group: xuecheng-plus-project
        file-extension: yaml
        # 以上内容完成是引入content-api-dev.yaml
        refresh-enabled: true
        # 引入扩展的配置文件content-service-dev.yaml
        extension-configs:
          - data-id: content-service-${spring.profiles.active}.yaml
            group: xuecheng-plus-project
            refresh: true
   ## 服务实例启动时的环境,默认为dev             
  profiles:
    active: dev

公用配置文件

实际开发中多个微服务模块的配置可能相同,此时我们可以编写一个公用的配置文件,然后添加shared-configs在不同服务中引入一个或多个配置文件

spring:
  application:
    name: content-api
  cloud:
    nacos:
      server-addr: localhost:8848
      discovery:
        namespace: dev
        group: xuecheng-plus-project
      config:
        namespace: dev
        group: xuecheng-plus-project
        file-extension: yaml
        # 以上内容完成是引入content-api-dev.yaml
        refresh-enabled: true
        # 引入公用的配置    
        shared-configs:
          - data-id: swagger-${spring.profiles.active}.yaml
            group: xuecheng-plus-common
            refresh: true
          - data-id: logging-${spring.profiles.active}.yaml
            group: xuecheng-plus-common
            refresh: true
  ## 服务实例启动时的环境,默认为dev           
  profiles:
    active: dev

配置热更新

配置热更新的目的就是在Nacos服务端修改远程配置文件后,对应使用该配置文件中配置的微服务实例无需重启修改后的配置也会生效

@RefreshScope

在使用@Value注解(注入远程配置文件的属性值)所在的类上添加@RefreshScope注解刷新作用域

第一步: 在Nacos服务端的配置文件中重新编辑日期格式并保存,此时无需重新启动服务,直接访问http://localhost:8081/user/test查看响应的日期的格式

pattern:
  # dateformat: yyyy年MM月dd日 HH:mm:ss
  dateformat: yyyy-MM-dd MM:hh:ss
@Slf4j
@RestController
@RequestMapping("/user")
// 刷新属性
@RefreshScope
public class UserController {
    @Value("${pattern.dateformat}")
    private String dateformat;

    @GetMapping("/test")
    public String test() {
        return LocalDateTime.now().format(DateTimeFormatter.ofPattern(dateformat));
    }
}

@ConfigurationProperties

使用@ConfigurationProperties注解代替@Value注解和@RefreshScope注解

第一步: 在user-service模块中新建一个PatternProperties属性配置类专门用来读取Nacos服务端中user-service-dev.yaml远程配置文件的属性

@Component
@Data
@ConfigurationProperties(prefix = "pattern")// 指定读取的属性前缀
public class PatternProperties {
    // "属性前缀+属性名"确定配置文件中的pattern.dateformat属性
    private String dateformat;
}

第二步: 在UserController中注入PatternProperties配置类,然后从中获取读到的pattern.dateformat属性

@Slf4j
@RestController
@RequestMapping("/user")
@RefreshScope
public class UserController {
    // 注入配置类
    @Autowired
    private PatternProperties patternProperties;

    @GetMapping("/test")
    public String test() {
        // 从PatternProperties类中获取读到的pattern.dateformat属性
        return LocalDateTime.now().format(DateTimeFormatter.ofPattern(patternProperties.getDateformat()));
    }
}

配置共享

共享步骤

微服务启动时会去Nacos服务端读取多个配置文件

  • [spring.application.name]-[spring.profiles.active].yaml: 远程配置文件名包含环境说明改变环境后就不能读取该配置文件中的内容
  • [spring.application.name].yaml: 远程配置文件名不包含环境说明即使改变环境后也可以读取该配置文件中的内容,一般写入多环境共享的配置

第一步: 在Nacos服务端中新建一个Data ID为user-service.yaml的远程配置文件,无论环境如何变化,user-service服务实例都可以读取到该配置文件的内容

pattern:
  envSharedValue: 多环境共享属性值

在这里插入图片描述

第二步: 在PatternProperties属性配置类中添加envSharedValue属性读取远程配置文件中的pattern.envSharedValue属性

@Component
@Data
@ConfigurationProperties(prefix = "pattern")
public class PatternProperties {
    private String dateformat;
    // 多环境共享属性值
    private String envSharedValue;
}

第三步: 在UserController中添加一个方法输出读取到的所有属性

@Slf4j
@RestController
@RequestMapping("/user")
public class UserController {
    @Autowired
    private PatternProperties patternProperties;

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

第四步: 在user-service模块的配置文件中添加spring.profiles.active属性更改服务实例启动时的环境或选择服务实例右键Edit Configuration

在这里插入图片描述

spring:
  application:
    name: user-service # 服务名称
  profiles:
    active: dev/test # 开发环境
  cloud:
    nacos:
      server-addr: localhost:8848 # Nacos地址
      config:
        file-extension: yaml # 文件后缀名

第五步: 打开浏览器分别访问http://localhost:8081/user/prop和http://localhost:8082/user/prop

  • UserApplication服务实例启动的环境是dev,所以加载的是user-service-dev.yml和user-service.yml这两个配置文件
  • UserApplication2服务实例启动的环境是test,所以加载的是user-service-test.yml和user-service.yml这两个配置文件
// UserApplication(dev环境)
{"dateformat": null,"envSharedValue": "多环境共享属性值"}
// UserApplication2(test环境)
{"dateformat": "yyyy-MM-dd HH:mm:ss","envSharedValue": "多环境共享属性值"}

配置共享的优先级

目前为止用到的配置文件有本地的配置文件bootstrap.yamlapplication.yaml以及Nacos上管理的远程配置文件

  • 远端配置大于本地配置,当前环境配置大于共享环境配置: bootstrap.yaml(确定Nacos地址和配置文件Id) > 服务名-环境名.yaml > 服务名.yaml > application.yaml

第一步: 在user-service模块本地application.yml中添加name属性验证: user-service-dev.yaml > user-service.yaml > application.yaml

pattern:
  name: 本地环境属性

第二步: 在Nacos服务端的远程配置文件user-service.yaml中新增name属性

pattern:
  name: 环境共享属性

第三步: 在Nacos服务端的远程配置文件user-service-dev.yaml中新增name属性

pattern:
  name: dev环境属性

第四步: 在PatternProperties属性配置类中添加name属性读取远程配置文件中的pattern.name属性

@Component
@Data
@ConfigurationProperties(prefix = "pattern")
public class PatternProperties {
    // 测试配置共享属性的优先级
    private String name;
}

第五步: 在UserController中添加一个方法输出读取到的所有属性

@Slf4j
@RestController
@RequestMapping("/user")
public class UserController {
    @Autowired
    private PatternProperties patternProperties;

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

配置本地优先

配置本地优先: 在模块的本地配置文件中添加spring.cloud.config.override-none配置提升本地配置的优先级,通过服务实例启动时的端口号验证

#配置本地优先
spring:
 cloud:
  config:
    override-none: true

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/247856.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

7. 异常、断言及日志

1.异常 1).什么是异常 异常&#xff0c;就是不正常的意思。指的是程序在执行过程中&#xff0c;出现的非正常的情况&#xff0c;最终会导致JVM的非正常停止。 在Java等面向对象的编程语言中&#xff0c;异常本身是一个类&#xff0c;产生异常就是创建异常对象并抛出了一个异常…

软件测试职业规划

软件测试人员的发展误区【4】 公司开发的产品专业性较强&#xff0c;软件测试人员需要有很强的专业知识&#xff0c;现在软件测试人员发展出现了一种测试管理者不愿意看到的景象&#xff1a; 1、开发技术较强的软件测试人员转向了软件开发(非测试工具开发)&#xff1b; 2、业务…

采埃孚4D成像雷达拆解

1 基本信息 品牌&#xff1a;海外Tier1采埃孚 • 应用&#xff1a;上汽飞凡中高端纯电平台 • 数量&#xff1a;单车2个&#xff0c;安装在前后保内部 • 最远探测距离&#xff1a;350米 拆解来看&#xff0c;4D雷达主要可以分为4个部分&#xff0c;分别为数字接口板及结构件…

mac视频调色 DaVinci Resolve Studio 18 中文 for Mac

DaVinci Resolve Studio 18是一款功能强大、专业可靠的视频编辑软件&#xff0c;适用于各种规模的媒体项目制作。无论是独立制片人还是大型制片公司&#xff0c;都可以借助该软件进行高质量的视频创作和后期制作。 得编辑工作更加高效和灵活。 调色和色彩校正&#xff1a;软件…

CSS的盒子模型(重点)

网页布局的三大核心&#xff1a;盒子模型、浮动、定位 网页布局的过程&#xff1a; 1. 先准备好相关的网页元素&#xff0c;网页元素基本都是盒子 Box 。 2. 利用 CSS 设置好盒子样式&#xff0c;然后摆放到相应位置。 3. 往盒子里面装内容.网页布局的核心本质&#xff1a; 就…

或许是全网最全的延迟队列

什么是延迟队列 作用&#xff1a;用来存储延迟消息延迟消息&#xff1a;生产者发送一个消息给mq&#xff0c;然后mq会经过一段时间&#xff08;延迟时间&#xff09;&#xff0c;然后在把这个消息发送给消费者 应用场景 预定会议后&#xff0c;需要在预定的时间点前十分钟通…

深拷贝、浅拷贝 react的“不可变值”

知识获取源–晨哥&#xff08;现实中的人 嘿嘿&#xff09; react中如果你想让一个值始终不变 或者说其他操作不影响该值 它只是作用初始化的时候 使用了浅拷贝–改变了初始值 会改变初始值(selectList1) 因为使用浅拷贝都指向同一个地址 const selectList1 { title: 大大, …

RabbitMQ入门案例

RabbitMQ 是目前比较主流的MQ消息队列中间件&#xff0c;下面简单总结RabbitMQ入门时所做的一些笔记 1.RabbitMQ 入门案例 需求&#xff1a;用 Java 编写两个程序。发送单个消息的生产者和接收消息并打印出来的消费者 1.1 添加依赖 <!--rabbitmq 依赖客户端--> <de…

开具实习证明:在线实习项目介绍

大数据在线实习项目&#xff0c;是在线上为学生提供实习经验的项目。我们希望能够帮助想要在毕业后从事数据科学类工作的学生更加顺利地适应从教室到职场的转换&#xff1b;也帮助那些在工作中需要处理数据、实现数据价值的其他职能的从业者高效快速地掌握每天都能用起来的数据…

Vue.js 使用基础知识

Vue.js 是一款用于构建用户界面的渐进式框架&#xff0c;它专注于视图层。Vue.js 不同于传统的 JavaScript 框架&#xff0c;它采用了组件化的开发方式&#xff0c;使得开发者可以更加高效和灵活地构建交互式的 Web 应用程序。 目录 什么是 Vue.js安装 Vue.jsVue 实例模板语法插…

2024年天津体育学院专升本专业课网上报名确认缴费安排

天津体育学院2024年高职升本科专业考试报名安排 一、时间安排 1.报名时间&#xff1a;2023年12月19日9&#xff1a;00-12月21日17&#xff1a;00 2.缴费时间&#xff1a;2023年12月26日-27日 &#xff08;考试考务费&#xff1a;体育教育专业&#xff1a;160元/人&#xff…

深入分析ClassLocader工作机制

文章目录 一、ClassLoader简介1. 概念2. ClassLoader类结构分析 二、ClassLoader的双亲委派机制三、Class文件的加载流程1. 简介2. 加载字节码到内存3. 验证与解析4. 初始化Class对象 四、常见加载类错误分析1. ClassNotFoundException2. NoClassDefFoundError3. UnsatisfiledL…

用Excel绘制柱形图

在需要将数据用柱状图表示的时候&#xff0c;可以用Excel进行绘制。不单绘制柱形图&#xff0c;其他数据图也可以用Excel绘制。 接下来用绘制一个销售表的示例演示。 1.将数据输入Excel 数学书 语文书 英语书 一月 80 94 77 二月 95 86 84 三月 130 93 79 四月 …

测出Bug就完了?从4个方面教你Bug根因分析

一现状及场景 1、缺失bug根因分析环节 工作10年&#xff0c;虽然不是一线城市&#xff0c;也经历过几家公司&#xff0c;规模大的、规模小的都有&#xff0c;针对于测试行业很少有Bug根因环节&#xff0c;主流程基本上都是测试提交bug-开发修改-测试验证-发送报告&#xff0c…

2023版本QT学习记录 -2- 标准文件对话框

头文件的使用 #include "QFileDialog"函数原型 getOpenFileName效果 参数 未完待续

工业固体废物智能化综合管控平台

工业固体废物智能化综合管控平台&#xff0c;涵盖产废企业、运输企业、固废处置企 业等不同群体应用&#xff0c;根据不同群体设计不同的业务应用子系统功能&#xff0c;以及各个不 同群体的环保物联网平台子系统功能模块&#xff0c;同时具有移动端的应用APP。 建立产废企业端…

SQL错题集4

1.注意格式 %Y是指date的年&#xff0c;%m是指date的月 %Y-%m ’ 即为2004-01 2.查询在2025-10-15以后&#xff0c;同一个用户下单1个以上状态为购买成功的C课程或Java课程或Python课程的user_id C或Java或Python --> 缩写 in ( C,Java,Python ) in ( ) 含义为 或or 3. ca…

用“价值”的视角来看安全:《构建新型网络形态下的网络空间安全体系》

作者简介&#xff1a; 懒大王敲代码&#xff0c;正在学习嵌入式方向有关课程stm32&#xff0c;网络编程&#xff0c;数据结构C/C等 今天给大家介绍《构建新型网络形态下的网络空间安全体系》这本书&#xff0c;希望大家能觉得实用&#xff01; 欢迎大家点赞 &#x1f44d; 收藏…

分库分表以后,如何实现扩容?

在实际开发中&#xff0c;数据库的扩容和不同的分库分表规则直接相关&#xff0c;今天我们从系统设计的角度&#xff0c;抽象了一个项目开发中出现的业务场景&#xff0c;从数据库设计、路由规则&#xff0c;以及数据迁移方案的角度进行讨论。 从业务场景出发进行讨论 假设这…

新产品创设过程理念:转变新产品创设的思维和过程

很多企业的新产品创设的过程属于预定义过程&#xff0c;即预先定义好客户群体 和产品的定位&#xff0c;然后列出产品的功能清单&#xff0c;技术可行性分析完成后开始研发。在产品发布给客户使用前&#xff0c;与客户的交互很少。在这个过程中存在大量 的没有验证的假设。预定…