Nacos配置中心组件学习
1. Nacos简介
1.1 Nacos是啥
Nacos(Dynamic Naming and Configuration Service)是一个开源的服务发现和配置管理平台,主要用于微服务架构中。Nacos的名字源自于“Naming and Configuration Service”的缩写,它提供了两大核心功能:服务发现和服务配置。上篇博文Naocos注册中心。下面我们一起来学习有关Nacos另外一个重要特性Nacos配置中心。
1.2 作用
- 服务发现:
- 允许服务之间相互发现和通信,支持基于DNS和基于RPC的服务发现。
- 服务提供者在启动时注册自己,服务消费者通过服务名查找服务,实现服务之间的解耦。
- 服务配置:
- 动态配置服务是Nacos的另一个重要功能,允许在所有环境中以集中和动态的方式管理所有服务的配置。
- 配置的更改可以自动推送到使用该配置的服务,实现配置的热更新,无需重启服务。
- 集中管理:
- 提供一个中央配置管理服务来统一管理所有服务的配置,避免了配置文件分散在各个项目里导致的不便维护问题。
- 动态更新:
- 能够在不重启服务的情况下,动态地更新配置,提高了系统的灵活性和可维护性。
- 版本控制&:
- 配置的变更被版本化,以便追踪变更历史和回滚到之前的配置,增强了配置的管理能力。
- 权限控制:
- 对配置的访问进行权限控制,确保只有授权的用户可以修改配置,提高了配置的安全性。
- 高可用性和故障转移:
- Nacos服务具有高可用性,能够在部分故障的情况下继续工作,并且能够从故障中恢复,保证了系统的稳定运行。
- 多环境配置:
- 支持多环境配置,如开发、测试和生产环境,可以实现环境隔离和配置加密,确保配置的正确性和安全性。
- 简化服务治理:
- Nacos无缝支持一些主流的开源生态,如Kubernetes Service、gRPC&Dubbo RPC Service、Spring Cloud RESTful Service等,使得服务治理更加容易和高效。
2. springCloud项目集成
前期准备:部署nacos服务,参考:Naocos注册中心
2.1 maven依赖
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
2.2 Nacos配置相关参数
通常使用bootstrap.properties或bootstrap.yml文件来配置Nacos的相关参数
spring:
application:
name: order-server
cloud:
nacos:
#nacos配置中心配置信息
config:
prefix: customer-server
namespace: nacos-xiu-dev
server-addr: 127.0.0.0:8848
file-extension: yml
# username: name
# password: pwd!
#nacos服务中心配置
discovery:
server-addr: 127.0.0.0:8848
namespace: nacos-xiu-dev
# username: name
# password: pwd!
在 Nacos Spring Cloud 中,dataId 的完整格式如下:
${prefix}-${spring.profiles.active}.${file-extension}
prefix默认为spring.application.name的值,也可以通过配置项spring.cloud.nacos.config.prefix来配置。spring.profiles.active即为当前环境对应的 profile,注意:当spring.profiles.active为空时,对应的连接符-也将不存在,dataId 的拼接格式变成${prefix}.${file-extension}file-exetension为配置内容的数据格式,可以通过配置项spring.cloud.nacos.config.file-extension来配置。目前只支持properties和yaml类型。
按照上述逻辑我们环境为dev在nacos服务里的文件为 命名空间:nacos-xiu-dev文件名称: customer-server-dev.yml。
2.3 配置信息
在nacos服务上添加配置信息如下:
nacos:
olympic:
games:
pingpangball: 马龙,樊振东,孙颖莎
dive: 全红婵,陈芋汐
shoot: 黄雨婷,盛李豪

| 配置项 | 说明 | 使用场景 |
|---|---|---|
| 命名空间(Namespace) | 用于进行不同环境的配置隔离,如开发环境、测试环境和生产环境等。 不同的命名空间下,可以存在相同名称的配置分组(Group)或配置集(Data ID)。 |
1.隔离不同环境的配置,防止环境间的配置相互干扰。 2.支持多租户配置隔离,不同租户可以使用相同的Nacos集群,但通过命名空间进行隔离 |
| 配置分组(Group) | 用于对配置集进行分组,不同的配置分组下可以有相同的配置集(Data ID)。 | 根据功能模块或组件进行配置分组,以便于管理。 |
| 配置集 (Data ID) |
一个配置文件就是一个配置集,包含了系统各个方面的配置信息。配置集通过Data ID来唯一标识。 | 配置文件,最细粒度的配置信息,开发最长接触的 |
| 多格式支持 | Nacos支持多种文件格式的配置项,包括JSON、XML、YAML、Properties、Text等。 | 常用的为 yaml文件、properties文件 |
2.5 配置使用
在你的Spring Boot应用中,你可以通过@Value注解或@ConfigurationProperties来注入这些配置。
@Value注入配置
@Value("${nacos.olympic.games.pingpangball}")
private String pingpangBall;
@GetMapping("/getOlympicName")
public String test() {
log.info("pingpangBall:{}",pingpangBall);
return "伦敦奥运会";
}
@ConfigurationProperties注入配置
//注意必须要有set/get方法
@Data
@Component
//设置配置信息前缀
@ConfigurationProperties(prefix = "nacos.olympic.games")
public class OlympicConfig implements Serializable {
/**
* 乒乓球
*/
private String pingpangBall;
/**
* 跳水
*/
private String dive;
/**
* 射击
*/
private String shoot;
}
使用
Nacos配置中心详解

最低0.47元/天 解锁文章
3533

被折叠的 条评论
为什么被折叠?



