详细介绍:Ribbon是如何与服务注册中心nacos交互的

news/2025/11/23 21:52:13/文章来源:https://www.cnblogs.com/gccbuaa/p/19261644

文章目录

      • 一、核心目标
      • 二、交互的前提:依赖与自动配置
        • 1. 关键依赖
        • 2. 自动调整
      • 三、详细交互流程
        • 阶段 1:初始化拉取实例列表(服务启动时)
        • 阶段 2:实时更新实例列表(运行时)
        • 阶段 3:实例过滤(基于 Nacos 健康状态)
      • 四、核心组件与交互关系
      • 五、与 Eureka 交互的对比(突出 Nacos 特性)
      • 总结

Ribbon 与服务注册中心(如 Nacos)的交互核心是获取目标服务的实例列表(IP、端口、状态等信息),并通过注册中心的服务发现机制实时感知实例的上下线变化,为负载均衡给予动态的实例数据支撑。以下以 Nacos 为例,详细解析交互流程和核心机制。

一、核心目标

Ribbon 与 Nacos 交互的最终目的是:让 Ribbon 能够实时获取目标服务(如 user-service)的所有可用实例列表,从而基于负载均衡策略(如轮询、随机)选择实例发起请求。

二、交互的前提:依赖与自动配置

Ribbon 与 Nacos 的交互需要依赖 Nacos 提供的服务发现客户端,以及 Ribbon 对 Nacos 的适配组件。

1. 关键依赖

在 Maven 项目中,需引入 Nacos 服务发现和 Ribbon 的依赖(Spring Cloud Alibaba 生态中已集成适配):

<!-- Nacos 服务发现客户端 --><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency><!-- Ribbon 核心依赖(通常已被 Nacos 依赖间接引入) --><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-ribbon</artifactId></dependency>
2. 自动配置

引入依赖后,Spring 会自动加载以下关键设置类,完成 Ribbon 与 Nacos 的对接:

  • NacosDiscoveryAutoConfiguration:初始化 Nacos 服务发现客户端(NacosDiscoveryClient),用于与 Nacos 服务器通信。
  • RibbonNacosAutoConfiguration:为 Ribbon 配置适配 Nacos 的 ServerList 实现(NacosServerList),让 Ribbon 能通过 Nacos 获取实例列表。

三、详细交互流程

Ribbon 与 Nacos 的交互可分为初始化拉取实时更新实例过滤三个核心阶段:

阶段 1:初始化拉取实例列表(服务启动时)

当客户端服务(集成了 Ribbon 和 Nacos)启动时,Ribbon 会通过 Nacos 客户端首次拉取目标服务的实例列表,流程如下:

  1. 触发 Ribbon 初始化
    客户端启动时,Ribbon 的 ILoadBalancer 组件(默认 BaseLoadBalancer)会初始化,触发 ServerList 组件的 getInitialListOfServers() 方法,请求初始实例列表。

  2. NacosServerList 对接 Nacos 服务器
    Ribbon 中适配 Nacos 的 NacosServerList 实现类会调用 Nacos 客户端的 NamingService 接口,向 Nacos 服务器发送请求:

    • 请求格式:GET /nacos/v1/ns/instance/list?serviceName=user-service(获取 user-service 的实例列表)。
    • Nacos 服务器返回该服务的所有实例数据(包括 IP、端口、权重、健康状态等)。
  3. 实例数据转换
    NacosServerList 将 Nacos 返回的实例数据(Instance 对象)转换为 Ribbon 可识别的 Server 对象(包含 IP、端口、元数据等),并返回给 ILoadBalancer

  4. 缓存初始实例列表
    ILoadBalancer 将初始实例列表缓存到本地,作为负载均衡的初始数据。

阶段 2:实时更新实例列表(运行时)

服务运行过程中,实例可能因上线、下线、故障等原因变化,Ribbon 需要经过 Nacos 实时感知这些变化,确保实例列表的准确性。更新机制有两种:主动轮询被动推送

  1. 主动轮询(Ribbon 触发)
    Ribbon 的 ServerListUpdater 组件会定期(默认 30 秒,可通过 ribbon.ServerListRefreshInterval 配置)调用 NacosServerListgetUpdatedListOfServers() 方法,主动从 Nacos 拉取最新实例列表:

  2. 被动推送(Nacos 触发)
    Nacos 客户端本身支持服务变更监听机制,当服务实例发生变化(如实例下线、权重调整)时,Nacos 服务器会主动推送变更通知给客户端。

阶段 3:实例过滤(基于 Nacos 健康状态)

Ribbon 获取到实例列表后,会通过 ServerListFilter 组件过滤掉不健康的实例,确保负载均衡仅选择可用实例。与 Nacos 结合时,过滤逻辑依赖 Nacos 对实例的健康状态标记:

  1. Nacos 的实例健康状态
    Nacos 中每个实例会通过心跳机制维持健康状态:

    • 实例启动后,会定期向 Nacos 服务器发送心跳(默认 5 秒)。
    • 若 Nacos 服务器超过 15 秒未收到心跳,会将实例标记为 不健康(DOWN)
  2. Ribbon 过滤不健康实例
    NacosServerList 拉取的实例列表中包含 Nacos 标记的健康状态,ServerListFilter(默认 ZoneAffinityServerListFilter)会过滤掉状态为 DOWN 的实例,仅保留 UP 的实例,作为负载均衡的候选列表。

四、核心组件与交互关系

组件/接口角色与作用与 Nacos 的交互点
NacosServerListRibbon 对接 Nacos 的 ServerList 实现类调用 NamingService 获取实例列表、订阅服务变更。
NamingServiceNacos 客户端核心接口,提供服务发现能力向 Nacos 服务器发送实例查询请求、注册变更监听。
ServerListUpdaterRibbon 的实例列表更新器定期触发 NacosServerList 拉取最新实例。
ServerListFilterRibbon 的实例过滤器基于 Nacos 返回的实例健康状态(UP/DOWN)过滤。

五、与 Eureka 交互的对比(突出 Nacos 特性)

维度与 Nacos 交互与 Eureka 交互
实例更新机制支持主动轮询 + 被动推送(实时性更高)仅拥护主动轮询(默认 30 秒,实时性较差)
健康状态依赖依赖 Nacos 服务器对实例的心跳检测结果依赖 Eureka 客户端自我上报的状态
适配组件NacosServerList (Spring Cloud Alibaba 提供)DiscoveryEnabledNIWSServerList(Netflix 提供)

总结

Ribbon 与 Nacos 的交互核心是通过 NacosServerList 组件对接 Nacos 的服务发现能力,实现“初始化拉取实例列表→运行时实时更新(轮询+推送)→基于健康状态过滤”的全流程,为 Ribbon 的负载均衡策略提供动态、准确的实例数据。这种交互机制确保了 Ribbon 能及时感知服务实例的变化,从而更高效地分发请求,提升系统的可用性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/974273.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Day46(16)-F:\硕士阶段\Java\课程代码\后端\web-ai-code\web-ai-project02\tlias-web-management

事务管理@Transactional(rollbackFor = {Exception.class})//事务管理的注解 - 默认出现RuntimeException才会回滚 @Override public void save(Emp emp) throws Exception{//1.保存员工的基本信息emp.setCreateTime(L…

完整教程:日本生活-东京新干线乘车经验-流程介绍

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

代码随想录算法训练营第三天:链表part01

代码随想录算法训练营第三天:链表part01**203.移除链表元素 ** leetcode链接:https://leetcode.cn/problems/remove-linked-list-elements/ 题目描述:给你一个链表的头节点 head 和一个整数 val ,请你删除链表中所…

2025-07-21-Mon-T-RocketMQ

1. 核心功能 1.1 MQ介绍 RocketMQ基本组件Topic: 消息归类的基本单元 Queue: 消息队列 Producer Consumer ConsumerGroup: NameServer:可以理解为注册中心,负责更新和发现Broker Broker集群:Broker 可以有一个或…

第一章 简介

关于简介这一章,作者简单阐明了CPU,GPU过去的发展,以及它们的差异。除此之外,作者还引入了CUDA,介绍了CUDA的代码类型,以及全书的结构。 此章值得注意的点如下: 1、GPU上的晶体管数量超过CPU上的。 2、两设备之间…

2025-07-13-Sun-T-AI-LangChain4j

1. 认识AI 1.1 神经元介绍 黑马LangChain4j入门到实战项目: 项目地址 软件架构 前端:静态页面后端框架:SpringbootLangchain4j + Ollama持久化:本地文件存储对话记录 (resources/memory) 用户预约信息存储在内存(…

P24_现有网络模型的使用及修改

P24_现有网络模型的使用及修改24.1 VGG16网络模型: (1)打开pytorch(0.9.0)—torchvision.models—VGG(2)参数点击查看代码 pretrained (bool) – If True, returns a model pre-trained on ImageNet progress (bo…

20232403 2025-2026-1 《网络与系统攻防技术》实验六实验报告

1.实验内容 主要内容:使用ARP扫描和nmap进行主机发现与端口扫描、Vsftpd后门漏洞获得root权限、Samba命令注入漏洞获取系统访问、Java RMI反序列化漏洞建立Meterpreter会话、PHP CGI参数注入漏洞。 掌握Metasploit命令…

第二讲类神经网络训练不起来

第二讲类神经网络训练不起来 一.优化失败的原因梯度为0有可能是local minima 和saddle point 因为计算优化的终止条件是梯度为0,但有可能梯度为0仅是局部最小值local minima或鞍点saddle point(多维,在某些维度是最…

【计算机网络】深入浅出DNS:网络世界的地址簿与导航系统 - 教程

【计算机网络】深入浅出DNS:网络世界的地址簿与导航系统 - 教程2025-11-23 21:39 tlnshuju 阅读(0) 评论(0) 收藏 举报pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !imp…

2025-01-24-Fri-T-如何做一个开源项目

创建和维护一个开源项目是一个非常有意义的工作,它可以帮助你与全球开发者合作,同时建立个人或团队的影响力。以下是详细步骤,帮你从零开始创建一个成功的开源项目。 1. 确定项目目标 解决实际问题:选择一个对你或…

利用大语言模型分析技术支持诈骗Facebook群组的网络犯罪研究

本文介绍了一项利用大语言模型分析Facebook上技术支持诈骗群组的研究,涉及38万条帖子的分类分析,揭示了网络犯罪服务的运作模式和最新趋势。网络犯罪与刑罚:我们在APWG eCrimes会议上关于技术支持诈骗Facebook群组的…

一些唐话

学OI学的言论均为转载 不保证言论可读你干嘛直接放 *3500 啊?!正经比赛里不是这样的!你应该先放两个简单签到,然后提升我的心态。偶尔给我送送强点的大样例,然后在那个我上厕所的时候跟我有神秘互动。最后在某个我…

2025-05-29-Thu-T-设计模式

目录1. 设计模式相关内容介绍1.1 设计模式概述1.2 UML类图类的表示方式类之间的关系表示方法1.3 软件设计原则1.1 开闭原则1.2 里氏代换原则1.3 依赖倒转/依赖倒置原则1.4 接口隔离原则1.5 迪米特法则1.6 合成复用原则…

2025-05-27-Tue-T-JVM

目录1 JVM与Java体系结构1.1 JVM 结构简图1.2 Java代码执行流程1.3 JVM的架构模型1.4 JVM的生命周期一、内存结构1. 程序计数器2. 虚拟机栈2.1 定义2.2 栈内存溢出2.3 线程运行诊断3. 本地方法栈4. 堆4.1 定义4.2 堆内…

11-28

今日掌握了 HashMap 的常用方法(put ()、get ()、containsKey ()),理解了键的唯一性,学会了遍历 Map 集合的两种方式(keySet、entrySet)。 明日计划学习多线程编程,重点理解线程的概念、创建方式(继承 Thread …

20232421 2025-2026-1 《网络与系统攻防技术》实验六实验报告

1.实践内容前期渗透主机发现 端口扫描 选做:也可以扫系统版本、漏洞等。Vsftpd源码包后门漏洞(21端口) SambaMS-RPC Shell命令注入漏洞(139端口) Java RMI SERVER命令执行漏洞(1099端口) PHP CGI参数执行注入漏…

20232315 2025-2026-1 《网络与系统攻防技术》实验六实验报告

20232315 2025-2026-1 《网络与系统攻防技术》实验六实验报告20232315 2025-2026-1 《网络与系统攻防技术》实验六实验报告 目录一、实验基本信息二、实验内容及要求三、实验过程3.1 前期渗透3.2 漏洞利用四、问题及解…

[CISCN 2022 华东北]duck WP

[CISCN 2022 华东北]duck WP[CISCN 2022 华东北]duck 一、题目来源 NSSCTF-Pwn-[CISCN 2022 华东北]duck二、信息搜集 通过 file 命令查看文件类型:通过 checksec 命令查看文件开启的保护机制:题目把 libc 文件和链接…

20232320 2025-2026-1 《网络与系统攻防技术》实验六实验报告

1.实验内容 总结一下本周学习内容,不要复制粘贴 2.实验过程 (1)前期渗透 ①主机发现(可用Aux中的arp_sweep,search一下就可以use) ②端口扫描:可以直接用nmap,也可以用Aux中的portscan/tcp等。 ③选做:也可以…