Nacos配置中心

简介: 本章基于Nacos实现配置中心,解决微服务架构中配置管理难题。通过引入nacos-config依赖与bootstrap.yaml文件,实现应用启动时优先加载远程配置,动态获取userservice-dev.yaml等环境配置,支持热更新、集中化管理,提升系统可用性与运维效率。

.引言
上一节我们借助于Nacos实现注册中心,完美替换了Eureka在项目之初的功能,开始本章节之前我们一起回忆下Nacos实现注册中心的关键步骤

  1. 引入springcloud-alibaba/nacos-discovery依赖
  2. 去除原eureka依赖、去除配置文件中eureka注册信息
  3. 新增nacos注册信息:spring.cloud.nacos.server-addr:localhost:8848
  4. 重启项目并验证
    在此基础之上我们验证了Nacos的负载均衡策略、权重控制、环境隔离等信息,希望大家还能有点印象。
    2.为什么需要配置中心
    试想最初的单体应用到如今的微服务部署(服务可能上百个),配置文件从修改到重启完成,服务中断可以按分钟计。以笔者负责应用为例,当数十数百个应用都需要修改配置,每个都重启部署的时候,服务中断将不再是可估算的现象。

因此我们需要一个类似注册中心的中间件,将配置中心从应用中解耦,应用不再是完全读取本地配置(部分不会频繁热更新的参数仍应用自身维护),而是直接拉取配置中心的信息作为应用参数,后续执行自己的业务流程。
下图为Nacos实现原理图:

但是引入配置中心的同时,我们不免思考一些Nacos已经遇到过、并成功解决的问题:
● 配置中心挂了怎么办?
● 谁负责将配置变更同步给应用?pull?push?
● 配置中心本身多节点部署,自身数据不同步又该如何解决呢?
Nacos是如何解决这些问题的,读者们可以参见上一节:Nacos白皮书或等笔者后续给出分析,基于上述背景,我们本章节将借助Nacos带领大家实现一个配置中心。
3.Nacos实现配置中心
3.1 新增配置信息
Nacos实现配置中心较为简单,首先在服务端新增一个配置信息(profile指项目运行环节:dev/test/pro)

注意:此处笔者新增在public空间下,如有部分读者是dev添加,则对应需要追加namespace(参见上节)

3.2 微服务拉取配置信息
配置完成之后,下一步就是在应用中拉取到刚才的配置信息。回顾我们原来的应用启动过程,应用启动时会读取本地配置文件application.yml,nacos也不例外他会将nacos配置信息同application.yml中的信息合并输出。那么问题来了:如果应用不能先读取到nacos配置信息(nacos地址-->配置信息)又怎么合并到一起呢?因此Spring引入一个新的配置文件:bootstarp.yaml文件,其读取顺序要优先于application.yml文件,如下:

1.引入nacos-config依赖
在user-service中新增nacos-config依赖


com.alibaba.cloud
spring-cloud-starter-alibaba-nacos-config

2.新增bootstrap.yaml文件
在user-service中新增配置文件:bootstrap.yaml,内容如下:
spring:
application:
name: userservice # 服务名称
profiles:
active: dev # 当前使用dev环境
cloud:
nacos:
server-addr: localhost:8848
config:
file-extension: yaml # 文件后缀名
此时应用就会使用以下规则作为文件的DataId匹配对应的配置文件:{spring.application.name}-${spring.procile.active}.${spring.cloud.nacos.config.file-extension}
以本例为准读取的即为:userservice-dev.yaml

相关文章
|
消息中间件 IDE Java
阿里云spring脚手架
阿里云spring脚手架
5378 1
|
Java 数据库连接 Maven
IDEA下Maven骨架(archetype)搭建
通过Maven生成骨架(通用项目目录结构)流程记录
2031 1
|
2月前
|
人工智能 前端开发 Java
【SpringAIAlibaba新手村系列】(4)流式输出与响应式编程
本文围绕 Spring AI 中的流式输出与响应式编程展开,重点解释了传统一次性响应与流式返回的差异,以及 Flux 在异步数据流中的核心作用。文章结合 ChatModel.stream() 与 ChatClient 的多种代码示例,说明如何实现 AI 内容的边生成边返回,并帮助读者理解流式调用在用户体验、性能和长文本场景中的实际价值。
677 4
【SpringAIAlibaba新手村系列】(4)流式输出与响应式编程
|
2月前
|
SQL 前端开发 Java
【分层架构】Spring MVC三层架构 / DDD领域驱动四层架构 / 微服务分布式架构(DAO/Mapper/Repository/Service/Controller/Manager)
本文系统解析Java企业级分层架构(Controller/Service/Manager/Repository/DAO/Mapper),阐明各层职责边界、设计原则与典型误区,强调单一职责、依赖倒置、关注点分离等核心思想,助力构建高内聚、低耦合、易维护的可扩展系统。
771 11
|
5月前
|
负载均衡 应用服务中间件 Nacos
Nacos配置中心
本文详细介绍如何使用Nacos实现微服务配置中心,涵盖配置管理、热更新、共享配置及优先级规则,并演示Nacos集群搭建与高可用部署,提升系统可维护性与稳定性。
 Nacos配置中心
|
负载均衡 Java Nacos
Spring Cloud五大组件
Spring Cloud五大组件
|
2月前
|
人工智能 JavaScript API
新手必看|OpenClaw阿里云部署流程+千问Qwen3-Max对接+避坑攻略
OpenClaw(曾用名Clawdbot、Moltbot)作为2026年开源AI智能体领域的核心工具,凭借“插件化技能体系+多模型兼容”的优势,成为个人与轻量团队提升效率的首选。它本身不具备独立大模型推理能力,需对接外部大模型才能实现“自然语言指令→任务执行”的完整闭环,而阿里云百炼平台的千问Qwen3-Max大模型,凭借免费调用额度、国内节点稳定性及与OpenClaw的无缝适配,成为新手对接的最优选择。
1033 1
|
Java 开发者 Spring
深入理解Spring Boot中的自动配置原理
深入理解Spring Boot中的自动配置原理
2914 1
|
Java API C++
Java 8 Stream Api 中的 peek 操作
本文介绍了Java中`Stream`的`peek`操作,该操作通过`Consumer<T>`函数消费流中的每个元素,但不改变元素类型。文章详细解释了`Consumer<T>`接口及其使用场景,并通过示例代码展示了`peek`操作的应用。此外,还对比了`peek`与`map`的区别,帮助读者更好地理解这两种操作的不同用途。作者为码农小胖哥,原文发布于稀土掘金。
923 9
Java 8 Stream Api 中的 peek 操作
|
前端开发 Java Apache
SpringBoot实现电子文件签字+合同系统!
【10月更文挑战第15天】 在现代企业运营中,合同管理和电子文件签字成为了日常活动中不可或缺的一部分。随着技术的发展,电子合同系统因其高效性、安全性和环保性,逐渐取代了传统的纸质合同。本文将详细介绍如何使用SpringBoot框架实现一个电子文件签字和合同管理系统。
1284 1

热门文章

最新文章