基于Spring Cloud Alibaba的微服务架构实战:Nacos配置管理

简介: 基于Spring Cloud Alibaba的微服务架构实战:Nacos配置管理

引言

Spring Cloud Alibaba 是 Spring Cloud 和 Alibaba 集团联合推出的开源微服务框架,旨在为 Java 开发者提供一种简单、易用、高效的微服务解决方案。Nacos 是一个面向云原生应用的动态服务发现、配置管理和服务管理平台,提供了服务注册与发现、配置管理、动态 DNS 服务、服务及流量管理等功能,是一个优秀的服务注册中心和配置中心。

本文将介绍 Spring Cloud Alibaba 整合 Nacos 的实战操作,包括 Nacos 的安装和部署,以及 Spring Cloud Alibaba 的依赖配置和使用。通过本文的学习,读者可以了解 Spring Cloud Alibaba 和 Nacos 的基本概念和使用方法,掌握微服务架构中服务注册和配置管理的基本技能。

一、Nacos 的安装和部署

1.1 下载 Nacos

Nacos 官网提供了多种下载方式,包括源码编译、Docker 镜像、二进制包等,读者可以根据自己的需求选择下载方式。

这里我们选择下载二进制包的方式进行安装,可以在官网下载页面选择对应版本的压缩包进行下载。当前最新版本为 2.0.3,下载地址为:

Release 2.0.3 (July 28, 2021) · alibaba/nacos · GitHub

1.2 安装 Nacos

将下载好的压缩包解压到任意目录,进入解压目录下的 bin 目录,执行以下命令即可启动 Nacos:

sh startup.sh -m standalone

执行成功后,可以在浏览器中访问 http://localhost:8848/nacos,进入 Nacos 的控制台界面。

1.3 部署服务

在 Nacos 控制台界面中,可以创建服务、配置数据等。下面我们以创建服务为例进行演示。

点击左侧菜单栏的“服务管理”,在右侧页面中选择“新建服务”,填写服务名和服务地址等信息,点击“新建”按钮即可完成服务的创建。


二、Spring Cloud Alibaba 的依赖配置

2.1引入依赖

在项目的 pom.xml 文件中,添加 Spring Cloud Alibaba 的依赖配置:

<dependencyManagement>
    <dependencies>
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-alibaba-dependencies</artifactId>
            <version>2.2.1.RELEASE</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
    </dependencies>
</dependencyManagement>
<dependencies>
    <!-- Nacos 服务注册和发现 -->
    <dependency>
        <groupId>com.alibaba.cloud</groupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
    </dependency>
    <!-- Nacos 配置管理 -->
    <dependency>
        <groupId>com.alibaba.cloud</groupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>php
        <version>2.2.1.RELEASE</version>
   </dependency>
</dependencies>

在这里,我们引入了 Spring Cloud Alibaba 的 Nacos 服务注册和发现以及配置管理的依赖。

2.2 配置文件

在项目的 application.properties 或 application.yml 文件中,添加 Nacos 相关的配置信息:

# Nacos 服务注册和发现
spring.cloud.nacos.discovery.server-addr=localhost:8848
# Nacos 配置管理
spring.cloud.nacos.config.server-addr=localhost:8848
spring.cloud.nacos.config.namespace=8f13df4e-fdc1-4a61-bfad-422d19b59f9a # 命名空间
spring.cloud.nacos.config.shared-dataids=example-config # 共享的配置文件 ID
spring.cloud.nacos.config.shared-dataids-refresh-interval=3000 # 共享的配置文件刷新间隔

在这里,我们配置了 Nacos 的服务地址、命名空间和共享的配置文件 ID 等信息。

三、Spring Cloud Alibaba 的使用

3.1 服务注册和发现

在 Spring Cloud Alibaba 中,可以通过 @EnableDiscoveryClient 注解启用服务注册和发现的功能。例如:

@SpringBootApplication
@EnableDiscoveryClient
public class ExampleServiceApplication {
    public static void main(String[] args) {
        SpringApplication.run(ExampleServiceApplication.class, args);
    }
}

在这里,我们启用了服务注册和发现的功能,并使用 @SpringBootApplication 注解标记了应用程序的入口类。

3.2 配置管理

在 Spring Cloud Alibaba 中,可以通过 @RefreshScope 和 @Value 注解来实现配置管理的功能。例如:

@RestController
@RefreshScope
public class ExampleController {
    @Value("${example.config}")
    private String exampleConfig;
    @GetMapping("/example")
    public String getExampleConfig() {
        return exampleConfig;
    }
}

在这里,我们使用 @RefreshScope 注解将 ExampleController 类标记为可刷新的 bean,使用 @Value 注解注入了 example.config 配置项的值。当配置项的值发生变化时,使用 @GetMapping 注解的 getExampleConfig 方法会返回最新的配置值。

四、总结

本文介绍了 Spring Cloud Alibaba 整合 Nacos 的实战操作,包括 Nacos 的安装和部署,以及 Spring Cloud Alibaba 的依赖配置和使用。通过本文的学习,读者可以了解 Spring Cloud Alibaba 和 Nacos 的基本概念和使用方法,掌握微服务架构中服务注册和配置管理的基本技能。

值得注意的是,在实际的开发中,可能会遇到更加复杂的微服务架构和业务场景。因此,读者在学习和使用 Spring Cloud Alibaba 和 Nacos 的过程中,应该根据具体的需求和场景进行合理的配置和使用,以达到最佳的效果和性能。

目录
相关文章
|
6月前
|
人工智能 Java Nacos
基于 Spring AI Alibaba + Nacos 的分布式 Multi-Agent 构建指南
本文将针对 Spring AI Alibaba + Nacos 的分布式多智能体构建方案展开介绍,同时结合 Demo 说明快速开发方法与实际效果。
4685 91
|
6月前
|
人工智能 运维 Java
Spring AI Alibaba Admin 开源!以数据为中心的 Agent 开发平台
Spring AI Alibaba Admin 正式发布!一站式实现 Prompt 管理、动态热更新、评测集构建、自动化评估与全链路可观测,助力企业高效构建可信赖的 AI Agent 应用。开源共建,现已上线!
7071 89
|
6月前
|
负载均衡 Java API
《深入理解Spring》Spring Cloud 构建分布式系统的微服务全家桶
Spring Cloud为微服务架构提供一站式解决方案,涵盖服务注册、配置管理、负载均衡、熔断限流等核心功能,助力开发者构建高可用、易扩展的分布式系统,并持续向云原生演进。
|
6月前
|
人工智能 监控 Java
Spring AI Alibaba实践|后台定时Agent
基于Spring AI Alibaba框架,可构建自主运行的AI Agent,突破传统Chat模式限制,支持定时任务、事件响应与人工协同,实现数据采集、分析到决策的自动化闭环,提升企业智能化效率。
Spring AI Alibaba实践|后台定时Agent
|
6月前
|
Cloud Native Serverless API
微服务架构实战指南:从单体应用到云原生的蜕变之路
🌟蒋星熠Jaxonic,代码为舟的星际旅人。深耕微服务架构,擅以DDD拆分服务、构建高可用通信与治理体系。分享从单体到云原生的实战经验,探索技术演进的无限可能。
微服务架构实战指南:从单体应用到云原生的蜕变之路
|
6月前
|
监控 Cloud Native Java
Spring Boot 3.x 微服务架构实战指南
🌟蒋星熠Jaxonic,技术宇宙中的星际旅人。深耕Spring Boot 3.x与微服务架构,探索云原生、性能优化与高可用系统设计。以代码为笔,在二进制星河中谱写极客诗篇。关注我,共赴技术星辰大海!(238字)
1150 2
Spring Boot 3.x 微服务架构实战指南
|
7月前
|
人工智能 Java 机器人
基于Spring AI Alibaba + Spring Boot + Ollama搭建本地AI对话机器人API
Spring AI Alibaba集成Ollama,基于Java构建本地大模型应用,支持流式对话、knife4j接口可视化,实现高隐私、免API密钥的离线AI服务。
6186 2
基于Spring AI Alibaba + Spring Boot + Ollama搭建本地AI对话机器人API
|
9月前
|
缓存 Cloud Native Java
Java 面试微服务架构与云原生技术实操内容及核心考点梳理 Java 面试
本内容涵盖Java面试核心技术实操,包括微服务架构(Spring Cloud Alibaba)、响应式编程(WebFlux)、容器化(Docker+K8s)、函数式编程、多级缓存、分库分表、链路追踪(Skywalking)等大厂高频考点,助你系统提升面试能力。
1012 0
|
Cloud Native Serverless 流计算
云原生时代的应用架构演进:从微服务到 Serverless 的阿里云实践
云原生技术正重塑企业数字化转型路径。阿里云作为亚太领先云服务商,提供完整云原生产品矩阵:容器服务ACK优化启动速度与镜像分发效率;MSE微服务引擎保障高可用性;ASM服务网格降低资源消耗;函数计算FC突破冷启动瓶颈;SAE重新定义PaaS边界;PolarDB数据库实现存储计算分离;DataWorks简化数据湖构建;Flink实时计算助力风控系统。这些技术已在多行业落地,推动效率提升与商业模式创新,助力企业在数字化浪潮中占据先机。
615 12
下一篇
开通oss服务