【无标题】

1.前言

除了注册中心和负载均衡之外, Nacos还是⼀个配置中心, 具备配置管理的功能.

Namespace 的常用场景之一是不同环境的配置区分隔离, 例如开发测试环境和⽣产环境的配置隔离。

1.1 为什么需要配置中心?

当前项目的配置都在代码中,会存在以下问题:

配置文件修改时,服务需要重新并部署。微服务架构中可能有成百个实例,挨个部署比较麻烦并且容易出错。
多个开发时,配置文件可能需要经常修改,使用同一个配置文件容易冲突。
配置中心就是对这些配置项进行统一管理,通过配置中心,可以其中查看,修改和删除配置,无需再逐个修改配置文件,提高效率的同时也降低了出错的风险。
在这里插入图片描述
服务启动时,从配置中心读取配置项的内容,进行初始化。
配置项修改时,通知微服务,实现配置的更新加载。

2. 入门程序

具体可以参考Nacos官网:Nacos Spring Cloud 快速开始

2.1 添加配置

在Nacos控制台添加配置项
在这里插入图片描述
新建配置项
在这里插入图片描述
配置内容:nacos.test.num = 5

说明:
配置内容的数据格式, 目前只支持 properties 和 yaml 类型。

2.2 获取配置内容

引入Nacos Config 配置中心的依赖
<!--        添加nacos配置中心的依赖-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
        </dependency>
<!--        spring_cloud 2020以后版本需要引入bootstrap的依赖 -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-bootstrap</artifactId>
        </dependency>
配置bootstrap.properties

微服务启动前,需要先获取Nacos中配置,并与application.yml配置合并, 在微服务运行之前, Nacos要求必须使用bootstrap.properties文件来配置Nacos Server 地址。
我以yml格式进行配置

spring:
  application:
    name: product-service # 设置应用程序的名称
  profiles:
    active: @profiles.name@ # 设置应用启动的环境,注意这里的配置文件会拼接在application.yml文件上面
  cloud:
    nacos:
      config:
        server-addr: 192.168.0.40:8848 # 设置了Nacos配置中心的地址为127.0.0.1:8848

spring.application.name: 这里设置了应用程序的名称为 “product-service”。这个名称通常用于注册服务到服务注册中心或者在日志中标识应用。

profiles.active: 这是设置应用启动的环境。@profiles.name@ 是一个占位符,它会被实际的配置文件名所替换。比如如果激活了名为 “dev” 的配置文件,那么实际的配置文件名就会变成 “application-dev.yml”。

cloud.nacos.config.server-addr: 这里配置了 Nacos 配置中心的地址为 “8.130.10.216:8848”。Nacos 是一个开源的分布式配置中心,这里指定了应用从该配置中心获取配置信息。

注意 配置中心和服务中心的环境是隔离的:

Nacos 配置中心:

spring: cloud: nacos: config: server-addr
Nacos 服务中心:

spring: cloud: nacos: discovery: server-addr
/**
 * @Description: 用于读取nacos中的配置项
 * @Author: sh
 * @Date: 2024/9/10 16:40
 */
@RestController
@RefreshScope
public class NacosController {

    @Value("${nacos.test.num}")
    private String nacosConfig;

    @RequestMapping("/getConfig")
    public String getConfig(){
        return "从Nacos中获取到了配置项" + nacosConfig;
    }
}

需要在启动类添加@RefreshScope 配置进行热更新
当配置中心中的配置信息发生变化时,通过@RefreshScope标记的Bean可以在不重启应用的情况下实现热更新。
在这里插入图片描述

3. 配置中心详解

3.1 设置命名空间

Nacos的服务中心和配置中心的命名空间是分别设置的,不属于同一配置。默认是public。
Nacos配置中心的命名空间在bootstrap.properties中进行配置的。

spring:
  cloud:
    nacos:
      config:
        server-addr: 192.168.0.40:8848 # 设置了Nacos配置中心的地址为127.0.0.1:8848
        namespace: 6beb0a84-3626-47a9-9d2e-56970d22c68e # 设置配置中心的命名空间

在这里插入图片描述
在这里插入图片描述
3.2 Data-ID(配置项)
Data Id 格式介绍
在 Nacos Spring Cloud 中, dataId 的完整格式如下:

${prefix}-${spring.profiles.active}.${file-extension}

Prefix 设置:
默认情况下,prefix 是根据 spring.application.name 的值确定的。
你也可以通过配置项 spring.cloud.nacos.config.prefix 来自定义 prefix。
Profile 设置:
spring.profiles.active 表示当前环境对应的 profile。
如果 spring.profiles.active 为空,连接符 - 也将不存在。
dataId 的拼接格式为 $ {prefix}.${file-extension},其中 file-extension 表示配置内容的数据格式。
可以通过配置项 spring.cloud.nacos.config.file-extension 来指定 file-extension,目前只支持 properties 和 yaml 类型,默认为 properties。
配置文件加载顺序:

$ {prefix}-$ {spring.profiles.active}.$ {file-extension},例如:product-service-dev.properties。
$ {prefix}.$ {file-extension},例如:product-service.properties。
$ {prefix},例如:product-service。
注意事项:

$ {spring.application.name}、$ {spring.profiles.active} 等配置必须放在 bootstrap.properties 文件中指定。
三个文件的优先级为: product-service-dev.properties > product-service.properties > product-service
在这里插入图片描述

4. Nacos配置中心总结

Nacos作为一个功能强大的服务发现和配置管理平台,不仅提供了注册中心和负载均衡的功能,还充当了配置中心的角色。在使用Nacos配置中心时,我们可以通过以下步骤轻松管理项目的配置项:

  1. 配置中心的必要性
    传统的配置文件管理方式存在诸多问题,如需重新部署服务、配置冲突等。
    配置中心能够统一管理配置项,提高效率,降低出错风险。
  2. 入门程序
    添加配置项到Nacos控制台,并通过依赖引入和配置文件配置,实现配置的读取和初始化。
  3. 配置中心详解
    命名空间设置: 可以通过命名空间进行不同环境的配置隔离,如开发测试环境和生产环境。
    Data-ID格式: Data-ID的格式包括prefix、profile、file-extension等,可根据项目需求进行自定义设置。
  4. Nacos配置中心总结
    Nacos作为一个功能强大的服务发现和配置管理平台,不仅提供了注册中心和负载均衡的功能,还充当了配置中心的角色。在使用Nacos配置中心时,我们可以通过以下步骤轻松管理项目的配置项:

原文链接:https://blog.csdn.net/m0_74749208/article/details/139524203

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值