Nacos作为配置中心详解

前言

在单体架构的时候我们可以将配置写在配置文件中,但有⼀个缺点就是每次修改配置都需要重启服务才能生效。
当应用程序实例比较少的时候还可以维护。如果转向微服务架构有成百上千个实例,每修改⼀次配置要将全部实例重启,不仅增加了系统的不稳定性,也提高了维护的成本。
在这里插入图片描述
那么如何能够做到服务不重启就可以修改配置?所有就产生了四个基础诉求:

  • 需要支持动态修改配置
  • 需要动态变更有多实时
  • 变更快了之后如何管控控制变更风险,如灰度、回滚等
  • 敏感配置如何做安全配置

Nacos配置模型

在这里插入图片描述

  1. Nacos 提供可视化的控制台,可以对配置进行发布、更新、删除、灰度、版本管理等功能。
  2. SDK 可以提供发布配置、更新配置、监听配置等功能。
  3. SDK 通过 GRPC 长连接监听配置变更,Server 端对比 Client 端配置的MD5 和本地MD5是否相等,不相等推送配置变更。
  4. SDK 会保存配置的快照,当服务端出现问题的时候从本地获取。

配置介绍

在 Nacos Spring Cloud 中,dataId 的完整格式如下:

${prefix}-${spring.profiles.active}.${file-extension}
  • prefix 默认为 spring.application.name 的值,也可以通过配置项 spring.cloud.nacos.config.prefix来配置。
  • spring.profiles.active 即为当前环境对应的 profile,详情可以参考 Spring Boot文档。 注意:当 spring.profiles.active 为空时,对应的连接符 - 也将不存在,dataId 的拼接格式变成 ${prefix}.${file-extension}
  • file-exetension 为配置内容的数据格式,可以通过配置项 spring.cloud.nacos.config.file-extension 来配置。支持 properties 、 yaml 和 yml 类型。

实际演练

在springcloud项目中要使用Nacos配置中心,就必须将相关信息配置到bootstrap(.properties/.yaml)配置文件中,所以要让springcloud识别bootstrap文件就要导入相关依赖:

		<dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-bootstrap</artifactId>
        </dependency>

然后在bootstrap文件中进行配置:

spring:
  cloud:
    nacos:
      discovery:	#nacos的地址,不写默认就是127.0.0.1:88848
        server-addr: 192.168.11.233:18848
        username: nacos
        password: nacos
      config:
        server-addr: 192.168.11.233:18848
        file-extension: yaml	#重点:文件格式就是在nacos中创建的配置文件是什么格式,要统一
        namespace: dev-namespace	# 命名空间的ID,我这里是自定义的,也可以自动生成,后面有讲解
        group: DEFAULT_GROUP	#默认组别,用于区分同一个namespace下的同名配置文件
        prefix: consumer01	#文件前缀,不写默认是 spring.application.name
  profiles:
    active: dev

由上面的配置可以得到文件名为:consumer01-dev.yaml,到Nacos中创建对应的配置文件:
首先创建命名空间:
因为我之前已经创建过dev了,现在以test为例:
在这里插入图片描述
在这里插入图片描述
然后到dev下创建配置文件:
在这里插入图片描述
这两个地方都可以创建:
在这里插入图片描述
写入自己的配置即可:
在这里插入图片描述
OK,然后就可以将原项目中的application.yaml删除或注释掉,重启项目,能够正常运行!

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
作为配置中心Nacos可以集成到Spring Cloud Alibaba技术栈中。我们可以使用Nacos来进行服务配置。在使用Nacos作为配置中心时,我们需要在配置文件中指定Nacos Server的地址,并配置命名空间ID和应用程序名称。\[1\]\[2\]\[3\] 具体来说,我们可以使用bootstrap.properties或者bootstrap.yaml配置文件来配置Nacos Server的地址。在配置文件中,我们需要指定Nacos Server的IP地址和端口号。同时,我们还可以配置Nacos的用户名和密码以进行身份验证。\[2\] 在使用Nacos作为配置中心时,我们需要在应用程序中配置spring.application.name属性。这是因为它是构成Nacos配置管理dataId字段的一部分。在Nacos Spring Cloud中,dataId的完整格式如下:\[3\] 通过使用Nacos作为配置中心,我们可以方便地管理和更新应用程序的配置信息。这使得我们可以在运行时动态地修改配置,而无需重新部署应用程序。同时,Nacos还提供了配置的版本管理和灰度发布等功能,使得配置管理更加灵活和可靠。 #### 引用[.reference_title] - *1* *3* [使用Nacos作为配置中心](https://blog.csdn.net/weixin_66202611/article/details/128089370)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Nacos配置中心使用](https://blog.csdn.net/qq_42402854/article/details/126375127)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值