springcloud/springboot集成NACOS 做注册和配置中心以及nacos源码分析

简介: 通过本文,我们详细介绍了如何在 Spring Cloud 和 Spring Boot 中集成 Nacos 进行服务注册和配置管理,并对 Nacos 的源码进行了初步分析。Nacos 作为一个强大的服务注册和配置管理平台,为微服务架构提供

Spring Cloud/Spring Boot 集成 Nacos 做注册和配置中心及源码分析

Nacos 是一个开源的动态服务发现、配置管理和服务管理平台,专为构建云原生应用而设计。它支持几乎所有主流的微服务框架,如 Spring Cloud 和 Dubbo。本文将详细介绍如何使用 Spring Cloud 和 Spring Boot 集成 Nacos 进行服务注册和配置管理,并对 Nacos 的源码进行分析。

一、Spring Cloud/Spring Boot 集成 Nacos

1. 环境准备

首先,确保已经安装并启动了 Nacos 服务器。可以通过以下命令下载并启动 Nacos 服务器:

wget https://github.com/alibaba/nacos/releases/download/1.4.1/nacos-server-1.4.1.zip
unzip nacos-server-1.4.1.zip
cd nacos/bin
sh startup.sh -m standalone
​
2. 在 Spring Boot 中集成 Nacos
2.1 添加依赖

pom.xml 中添加 Nacos 依赖:

<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
​
2.2 配置 Nacos

application.yml 中配置 Nacos 连接信息:

spring:
  application:
    name: nacos-demo
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848
      config:
        server-addr: localhost:8848
        file-extension: yaml
​
2.3 启用 Nacos

在 Spring Boot 主应用类中启用 Nacos 服务注册和配置:

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

二、Nacos 的使用示例

1. 服务注册与发现

创建一个简单的 REST 控制器,展示服务注册与发现的功能:

@RestController
public class TestController {

    @Autowired
    private DiscoveryClient discoveryClient;

    @GetMapping("/services")
    public List<String> services() {
        return discoveryClient.getServices();
    }

    @GetMapping("/instances/{serviceId}")
    public List<ServiceInstance> instances(@PathVariable String serviceId) {
        return discoveryClient.getInstances(serviceId);
    }
}
​
2. 配置管理

在 Nacos 控制台中,创建一个名为 nacos-demo.yaml 的配置文件,内容如下:

test:
  message: "Hello Nacos Config"
​

在 Spring Boot 应用中,通过 @Value 注解读取配置:

@RestController
public class ConfigController {

    @Value("${test.message}")
    private String message;

    @GetMapping("/config")
    public String getConfig() {
        return message;
    }
}
​

三、Nacos 源码分析

1. Nacos 的架构

Nacos 的架构包括服务注册、配置管理和服务发现。主要组件包括:

  • Naming 模块:处理服务注册和发现。
  • Config 模块:处理配置管理。
2. Naming 模块源码分析

Naming 模块的核心类是 com.alibaba.nacos.naming.NamingService。该类负责服务注册、心跳检测和服务发现。

2.1 服务注册

服务注册通过 registerInstance 方法实现:

@Override
public void registerInstance(String serviceName, String groupName, Instance instance) throws NacosException {
    String groupedServiceName = NamingUtils.getGroupedName(serviceName, groupName);
    serverProxy.registerService(groupedServiceName, instance);
}
​

serverProxy.registerService 方法负责将服务实例信息发送到 Nacos 服务器。

2.2 服务发现

服务发现通过 getAllInstances 方法实现:

@Override
public List<Instance> getAllInstances(String serviceName, String groupName) throws NacosException {
    String groupedServiceName = NamingUtils.getGroupedName(serviceName, groupName);
    return serverProxy.getAllInstances(groupedServiceName, new ArrayList<>());
}
​
3. Config 模块源码分析

Config 模块的核心类是 com.alibaba.nacos.client.config.NacosConfigService。该类负责从 Nacos 服务器获取配置信息。

3.1 配置获取

配置获取通过 getConfig 方法实现:

@Override
public String getConfig(String dataId, String group, long timeoutMs) throws NacosException {
    return worker.getServerConfig(dataId, group, timeoutMs);
}
​

worker.getServerConfig 方法负责从 Nacos 服务器获取配置数据。

3.2 配置监听

配置监听通过 addListener 方法实现:

@Override
public void addListener(String dataId, String group, Listener listener) throws NacosException {
    manager.addListener(dataId, group, listener);
}
​

manager.addListener 方法负责在配置变更时通知监听器。

四、总结

通过本文,我们详细介绍了如何在 Spring Cloud 和 Spring Boot 中集成 Nacos 进行服务注册和配置管理,并对 Nacos 的源码进行了初步分析。Nacos 作为一个强大的服务注册和配置管理平台,为微服务架构提供

目录
相关文章
|
SQL Java 关系型数据库
Dataphin功能Tips系列(53)-离线集成任务如何合理配置JVM资源
本文探讨了将MySQL数据同步至Hive时出现OOM问题的解决方案。
426 5
|
缓存 Java API
微服务——SpringBoot使用归纳——Spring Boot集成 Swagger2 展现在线接口文档——Swagger2 的配置
本文介绍了在Spring Boot中配置Swagger2的方法。通过创建一个配置类,添加`@Configuration`和`@EnableSwagger2`注解,使用Docket对象定义API文档的详细信息,包括标题、描述、版本和包路径等。配置完成后,访问`localhost:8080/swagger-ui.html`即可查看接口文档。文中还提示了可能因浏览器缓存导致的问题及解决方法。
1364 0
微服务——SpringBoot使用归纳——Spring Boot集成 Swagger2 展现在线接口文档——Swagger2 的配置
|
JSON JavaScript API
MCP 实战:用配置与真实代码玩转 GitHub 集成
MCP 实战:用配置与真实代码玩转 GitHub 集成
2719 4
|
缓存 前端开发 API
(网页系统集成CAD功能)在线CAD中配置属性的使用教程
本文介绍了Mxcad SDK在线预览和编辑CAD图纸的功能及配置方法。通过Vite、CDN或Webpack实现集成,用户可自定义设置以满足项目需求。主要内容包括:1)`createMxCad()`方法的初始属性配置,如画布ID、WASM文件路径、字体加载路径等;2)`MxFun.setIniset()`方法提供的更多CAD初始配置;3)`McObject`对象API用于动态调整视图背景色、浏览模式等。此外,还提供了在线Demo(https://demo2.mxdraw3d.com:3000/mxcad/)供用户测试实时效果。
|
Java 数据库连接 数据库
微服务——SpringBoot使用归纳——Spring Boot集成MyBatis——MyBatis 介绍和配置
本文介绍了Spring Boot集成MyBatis的方法,重点讲解基于注解的方式。首先简述MyBatis作为持久层框架的特点,接着说明集成时的依赖导入,包括`mybatis-spring-boot-starter`和MySQL连接器。随后详细展示了`properties.yml`配置文件的内容,涵盖数据库连接、驼峰命名规范及Mapper文件路径等关键设置,帮助开发者快速上手Spring Boot与MyBatis的整合开发。
1932 0
|
缓存 Java 应用服务中间件
微服务——SpringBoot使用归纳——Spring Boot集成Thymeleaf模板引擎——依赖导入和Thymeleaf相关配置
在Spring Boot中使用Thymeleaf模板,需引入依赖`spring-boot-starter-thymeleaf`,并在HTML页面标签中声明`xmlns:th=&quot;http://www.thymeleaf.org&quot;`。此外,Thymeleaf默认开启页面缓存,开发时建议关闭缓存以实时查看更新效果,配置方式为`spring.thymeleaf.cache: false`。这可避免因缓存导致页面未及时刷新的问题。
534 0
|
存储 网络协议 Nacos
高效搭建Nacos:实现微服务的服务注册与配置中心
Nacos(Dynamic Naming and Configuration Service)是阿里巴巴开源的一款动态服务发现、配置管理和服务管理平台。它旨在帮助开发者更轻松地构建、部署和管理分布式系统,特别是在微服务架构中。
2943 81
高效搭建Nacos:实现微服务的服务注册与配置中心
|
存储 Kubernetes 安全
Nacos-Controller 2.0:使用 Nacos 高效管理你的 K8s 配置
无论是使用 Nacos-Controller 实现配置的双向同步,还是直接在应用中接入 Nacos SDK 以获得更高级的配置管理特性,都能显著提升配置管理的灵活性、安全性和可维护性。使用 Nacos,您能够更好地管理和优化您的应用配置,从而提高系统的稳定性和可靠性。
1130 50
|
JSON Java Nacos
SpringCloud 应用 Nacos 配置中心注解
在 Spring Cloud 应用中可以非常低成本地集成 Nacos 实现配置动态刷新,在应用程序代码中通过 Spring 官方的注解 @Value 和 @ConfigurationProperties,引用 Spring enviroment 上下文中的属性值,这种用法的最大优点是无代码层面侵入性,但也存在诸多限制,为了解决问题,提升应用接入 Nacos 配置中心的易用性,Spring Cloud Alibaba 发布一套全新的 Nacos 配置中心的注解。
1850 151
|
监控 Java 测试技术
Nacos 配置中心变更利器:自定义标签灰度
本文是对 MSE Nacos 应用自定义标签灰度的功能介绍,欢迎大家升级版本进行试用。
1306 212