什么是ribbon?
Ribbo是一个基于HTTP和TCP的客户端负载均衡器
什么是客户端负载均衡?
客户端负载均衡和服务端负载均衡最大的区别在于服务清单所存储的位置。
在客户端负载均衡中,所有的客户端节点都有一份自己要访问的服务端清单,客户端在发起请求的时候会先自行选择一个服务端,向该服务端发起请求,从而实现负载均衡
ribbon的职能主要有两个:
1、维护所有的服务实例SeverList(新增、更新、删除等)
2、当需要请求Server实例时,从SeverList中找到最合适的Server实例并返回
维护server列表
1、基于定时任务拉取服务列表方式,然后将最新的服务列表更新到ServerList之中(默认30s一次从Eureka服务端拉取)
2、基于Eureka服务事件通知的方式,来更新ServerList(例如:有新服务注册,或有服务down机,会有事件通知)
选择服务实例的流程
1、通过ServerList获取当前可用的服务实例列表
2、使用ServerListFilter过滤器过滤出符合要求的服务实例列表
(Ribbon默认采取了区域优先的过滤策略,即从ServerList中过滤出和当前实例所在的区域(zone)一致的serverList)
3、应用Rule规则,结合服务实例的统计信息,返回满足规则的某一个服务实例
说明:在服务实例列表选择的过程中,有两次过滤的机会
第一次是首先通过ServerListFilter过滤器
另外一次是用过Rule的选择规则进行过滤
rule规则
1、RoundRobinRule 线性轮询
2、RandomRule 随机
3、WeightedResponseTimeRule 权重
4、BestAvailableRule 选出最空闲的实例
5、RetryRule 线性轮询重试
6、ZoneAvoidanceRule
计算出哪个区域的服务最差,将此zone的服务从服务列表中剔除
再过滤掉正处于熔断状态的服务
然后通过RoundRobinRule线性轮询的方式从列表中挑选一个服务
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· winform 绘制太阳,地球,月球 运作规律
· 上周热点回顾(3.3-3.9)