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 # 远程配置文件所在的命名空间名称或IDgroup: 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-apicloud:nacos:server-addr: 127.0.0.1:8848discovery:namespace: ${spring.profiles.active}group: xuecheng-plus-projectconfig:namespace: ${spring.profiles.active}group: xuecheng-plus-projectfile-extension: yaml# 以上内容完成是引入content-api-dev.yamlrefresh-enabled: true# 引入扩展的配置文件content-service-dev.yamlextension-configs:- data-id: content-service-${spring.profiles.active}.yamlgroup: xuecheng-plus-projectrefresh: true## 服务实例启动时的环境,默认为dev             profiles:active: dev

公用配置文件

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

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

配置热更新

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

@RefreshScope

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

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

pattern:# dateformat: yyyy年MM月dd日 HH:mm:ssdateformat: 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 {// 注入配置类@Autowiredprivate 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 {@Autowiredprivate 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 {@Autowiredprivate PatternProperties patternProperties;@GetMapping("/prop")public PatternProperties prop(){return patternProperties;}
}

配置本地优先

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

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

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

源码角度简单介绍LinkedList

LinkedList是一种常见的数据结构&#xff0c;但是大多数开发者并不了解其底层实现原理&#xff0c;以至于存在很多误解&#xff0c;在这篇文章中&#xff0c;将带大家一块深入剖析LinkedList的源码&#xff0c;并为你揭露它们背后的真相。首先想几个问题&#xff0c;例如&#…

C++初阶-string类的模拟实现

string类的模拟实现 一、经典的string类问题1.1 构造函数1.1.1 全缺省的构造函数 2.1 拷贝构造3.1 赋值4.1 析构函数5.1 c_str6.1 operator[]7.1 size8.1 capacity9.1 比较&#xff08;ASCII&#xff09;大小10.1 resize11.1 reserve12.1 push_back(尾插字符)13.1 append(尾插字…

MIT18.06线性代数 笔记3

文章目录 对称矩阵及正定性复数矩阵和快速傅里叶变换正定矩阵和最小值相似矩阵和若尔当形奇异值分解线性变换及对应矩阵基变换和图像压缩单元检测3复习左右逆和伪逆期末复习 对称矩阵及正定性 特征值是实数特征向量垂直>标准正交 谱定理&#xff0c;主轴定理 为什么对称矩…

PaddleOCR:超越人眼识别率的AI文字识别神器

在当今人工智能技术已经渗透到各个领域。其中&#xff0c;OCR&#xff08;Optical Character Recognition&#xff09;技术将图像中的文字转化为可编辑的文本&#xff0c;为众多行业带来了极大的便利。PaddleOCR是一款由百度研发的OCR开源工具&#xff0c;具有极高的准确率和易…

Python从入门到精通七:Python函数进阶

函数多返回值 学习目标&#xff1a; 知道函数如何返回多个返回值 问: 如果一个函数如些两个return (如下所示)&#xff0c;程序如何执行&#xff1f; 答&#xff1a;只执行了第一个return&#xff0c;原因是因为return可以退出当前函数&#xff0c;导致return下方的代码不执…

(3)kylin系统部署weblogic项目

一、jdk迁移 1、拷贝成功后要配置环境变量 vi /etc/profile 将jdk的目录添加进去 2、将jdk安装目录拷贝后权限会发生变化&#xff0c; 要对jdk下bin目录中的所有文件修改权限&#xff1a; chmod x ./* 回车即可 ----------------------------- 环境变量 export …

DBeaver连接kingbase8(人大金仓)

DBeaver连接kingbase8(人大金仓) 1、添加驱动 步骤&#xff1a;选择"数据库-->驱动管理器" 类名&#xff1a;com.kingbase8.Driver URL模板&#xff1a;jdbc:kingbase8://{host}[:[{post}]/[{database}] 端口&#xff1a;54321 添加jar包 2、连接数据库 点击…

Python 进阶(十六):二进制和ASCII码的转换(binascii 模块)

大家好&#xff0c;我是水滴~~ 本文详细介绍了Python中的binascii模块及其使用方法。通过binascii模块&#xff0c;我们可以方便地进行二进制和ASCII字符串之间的转换操作。文章中包含大量的示例代码&#xff0c;希望能够帮助新手同学快速入门。 《Python入门核心技术》专栏总…

【OPENGIS】Geoserver升级Jetty,不修改java版本

昨天搞了一个geoserver升级9.4.53版本的方法&#xff0c;但是需要修改java的版本&#xff0c;因为jetty官方网站下载的jar包是用jdk11编译的&#xff0c;如果不升级java版本&#xff0c;运行就会报错。 可是现场环境限制比较多&#xff0c;升级了java版本之后有些老版本的程序又…

【模拟】LeetCode-48. 旋转图像

旋转图像。 给定一个 n n 的二维矩阵 matrix 表示一个图像。请你将图像顺时针旋转 90 度。 你必须在 原地 旋转图像&#xff0c;这意味着你需要直接修改输入的二维矩阵。请不要 使用另一个矩阵来旋转图像。 示例 1&#xff1a; 输入&#xff1a;matrix [[1,2,3],[4,5,6]…

Python 进阶(十五):Base64 编码和解码(base64 模块)

大家好&#xff0c;我是水滴~~ 本篇文章主要介绍Python的base64模块&#xff0c;主要内容有&#xff1a;Base64的概念、base64模块、base64编码和解码、以及其使用场景。文章中包含大量的示例代码&#xff0c;希望能够帮助新手同学快速入门。 《Python入门核心技术》专栏总目录…

ardupilot开发 --- git 篇

一些概念 工作区&#xff1a;就是你在电脑里能看到的目录&#xff1b;暂存区&#xff1a;stage区 或 index区。存放在 &#xff1a;工作区 / .git / index 文件中&#xff1b;版本库&#xff1a;本地仓库&#xff0c;存放在 &#xff1a;工作区 / .git 中 关于 HEAD 是所有本地…

逆序对的数量

归并排序模板题 相关文章 //采用归并排序,归并的过程可以算出逆序对的个数//所有的逆序对个数 /*排序后,两个数都在左边的逆序对数排序后,两个数都在右边的逆序对数如果一个数在左边,一个数在右边,在归并的过程中*/ //左边 < 右边,正常归并。如果左边 > 右边 //那么左边…

【头歌系统数据库实验】实验9 SQL视图

目录 第1关&#xff1a;请为三建工程项目建立一个供应情况的视图V_SPQ&#xff0c;包括供应商代码(SNO)、零件代码(PNO)、供应数量(QTY) 第2关&#xff1a;从视图V_SPQ找出三建工程项目使用的各种零件代码及其数量 第3关&#xff1a;从视图V_SPQ找出供应商S1的供应情况 第4…

2024世界燕窝滋补品展|上海燕博会推荐品牌天健燕窝集团-为消费者带来好燕窝!

天健燕窝集团拥有27年燕窝进出口贸易经验。是最早加入经营正规燕窝业务的企业之一&#xff0c;业务范围遍布全中国&#xff0c;2015 年至2019 年连续5年燕窝进口量全国第一。 一年一届的世界燕窝及天然滋补品博览会暨世界滋补生态发展大会&#xff08;简称上海燕博会&#xff…

网格中的最小路径代价

说在前面 &#x1f388;不知道大家对于算法的学习是一个怎样的心态呢&#xff1f;为了面试还是因为兴趣&#xff1f;不管是出于什么原因&#xff0c;算法学习需要持续保持。 问题描述 给你一个下标从 0 开始的整数矩阵 grid &#xff0c;矩阵大小为 m x n &#xff0c;由从 0 …

VUE3语法--toRefs与toRef用法

1、功能概述 ref和reactive能够定义响应式的数据&#xff0c;当我们通过reactive定义了一个对象或者数组数据的时候&#xff0c;如果我们只希望这个对象或者数组中指定的数据响应&#xff0c;其他的不响应。这个时候我们就可以使用toRefs和toRef实现局部数据的响应。 toRefs是…

CentOS7 安装包 MariaDB 10.4.x

CentOS7 安装包 MariaDB 10.4.x 统一 MariaDB安装包 https://www.alipan.com/s/fvLg3gN7LPX 提取码: nh81 打开「阿里云盘」

关于Anaconda的安装和环境部署(此章专为新手制定)

目录 Anaconda简介 一、软件下载&#xff08;地址&#x1f447;&#xff09; 2&#xff1a;点击下载 3&#xff1a;版本选择&#xff1a; 4&#xff1a;Anaconda的安装包就下载完成了 2&#xff1a;恭喜你&#xff0c;看到这里已经完成安装了 三、部署环境 1&#xff1…

什么是 AWS IAM?如何使用 IAM 数据库身份验证连接到 Amazon RDS(上)

驾驭云服务的安全环境可能很复杂&#xff0c;但 AWS IAM 为安全访问管理提供了强大的框架。在本文中&#xff0c;我们将探讨什么是 AWS Identity and Access Management (IAM) 以及它如何增强安全性。我们还将提供有关使用 IAM 连接到 Amazon Relational Database Service (RDS…