1、nacos

一、安装

\[Docker常用的容器#nacos\]

二、服务注册与发现

以在项目中添加服务发现依赖

xml 复制代码
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>

在配置文件中配置Nacos注册中心的地址:

yml 复制代码
spring:  
  application:  
    name: service-order  
  profiles:  
    active: dev   # 当前环境
    include: feign # 包含feign配置  
  config:  
    import:  
      - nacos:common.yml  
      - nacos:database.yml  
  cloud:  
    nacos:  
      server-addr: 192.168.88.139:8848  
      discovery:  
        username: nacos  
        password: nacos
        # namespace: f923fb34-cb0a-4c06-8fca-ad61ea61a3f0  
		# group: DEFAULT_GROUP
        # register-enabled: false # 禁用注册
      config:  
        namespace: 39ee5118-3bac-42d8-91d8-58a7f2ba0c12 # 命名空间
        username: nacos  
        password: nacos  
        group: order  # 分区
  • Namespace (命名空间):用于环境隔离(如 Dev, Test, Prod)
  • Group (分组):用于区分不同的项目或模块,默认是 DEFAULT_GROUP

接着启动服务,可以在Nacos的服务列表中找到:

扩展(了解即可)

java 复制代码
/**
 * 功能: 测试 Nacos 服务注册与发现
 * 作者: 沙琪马
 * 日期: 2025/11/17 14:32
 */
@SpringBootTest
public class DiscoveryTest {

    @Resource
    private DiscoveryClient discoveryClient;  // Spring Cloud 标准接口

    @Resource
    private NacosDiscoveryClient nacosDiscoveryClient;  // Nacos 特有实现

    /**
     * 使用 Nacos 特有客户端获取服务列表及实例
     */
    @Test
    void testNacosDiscoveryClient() {
        System.out.println("=== 使用 NacosDiscoveryClient ===");
        List<String> services = nacosDiscoveryClient.getServices();
        for (String service : services) {
            System.out.println("Service: " + service);
            List<Instance> instances = nacosDiscoveryClient.getInstances(service);
            instances.forEach(instance -> 
                System.out.println("  → " + instance.getIp() + ":" + instance.getPort())
            );
        }
    }

    /**
     * 使用标准 DiscoveryClient 获取服务(推荐,解耦)
     */
    @Test
    void testDiscoveryClient() {
        System.out.println("=== 使用 DiscoveryClient(标准)===");
        List<String> services = discoveryClient.getServices();
        for (String service : services) {
            System.out.println("Service: " + service);
            List<ServiceInstance> instances = discoveryClient.getInstances(service);
            instances.forEach(instance -> 
                System.out.println("  → " + instance.getHost() + ":" + instance.getPort())
            );
        }
    }
}

三、远程调用

这里主要使用 \[2、OpenFeign] 来实现了

四、配置中心

数据隔离

  • 需求描述
    • 项目有多套环境:dev、test、prod
    • 每个微服务,同一种配置,在每套环境的值都不一样
    • 项目可以通过切换环境,加载本环境的配置
  • 难点
    • 区分多套环境
    • 区分多种微服务
    • 区分多种配置
    • 按需加载配置

总结

注册中心

  1. 引入 spring-cloud-starter-alibaba-nacos-discovery 依赖,配置Nacos地址
  2. @EnableDiscoveryClient 开启服务发现功能(默认是开启的)

扩展

  1. ={red}DiscoveryClient= 获取服务实例列表
  2. ={red}LoadBalancerClient= 负载均衡选择一个实例(需要引入 spring-cloud-starter-loadbalancer)
  3. ={red}RestTemplate= 可以发起远程调用

配置中心

  1. 引入 spring-cloud-starter-alibaba-nacos-config 依赖,配置Nacos地址
  2. 添加数据集 (data-id),使用 ={orange}spring.config.import= 导入数据集
  3. ~={orange}@Value + @RefreshScope=~ 取值 + 自动刷新
  4. @ConfigurationProperties 默认就支持自动刷新
  5. ={orange}NacosConfigManager= 监听配置变化

扩展:

配置优先级;namespace区分环境、group区分微服务、data-id区分配置 实现 数据隔离+环境切换


面试题

Nacos中的数据集 和 application.properties 有相同的配置项,哪个生效?

答案 :

以配置中心的配置为准,实现快捷的统一管理

相关推荐
许彰午16 小时前
30_Java Stream流操作全解
java·windows·python
星间都市山脉18 小时前
Android STS(Security Test Suite)完整介绍与测试流程
android·java·linux·windows·ubuntu·android studio·androidx
xiaoliuliu1234520 小时前
Sketchpad 5.0.6 几何画板安装版配置教程 Windows版:部署+桌面快捷方式创建指南
windows
惊鸿一博21 小时前
网络端口开放访问权限_Windows 11 上确保防火墙允许指定端口如3001可被访问
网络·windows
软件无线电小方圆1 天前
Windows下基于PyQt6上位机开发环境搭建
windows
蜀道山老天师1 天前
OpenClaw Skills 技能开发 + 企业运维全场景实战(进阶篇)
人工智能·windows·microsoft
舟遥遥娓飘飘1 天前
文稿起草系统,离线学习写作人的“思维 + 风格“,按学到的特征起草新文稿,再用反馈闭环持续提升
windows·学习
至此流年莫相忘1 天前
Windows 环境下 RocketMQ 安装与 NSSM 后台服务化部署指南
windows·rocketmq
AI行业学习1 天前
CC‑Switch v3.16.1 免费下载(Windows+macOS+Linux)、使用方法【2026.6.11】
linux·开发语言·windows·python·macos·前端框架·html
啦啦啦~~~3301 天前
【装机工具】电脑重装系统!office安装管理软件!一键自动化下载、安装、部署Office的办公增强工具
运维·c语言·windows·自动化·电脑