Spring Cloud Ribbon 客户端负载均衡

Spring Cloud Ribbon [ˈrɪbən] 是一个基于 HTTP 和 TCP客户端负载均衡工具,它基于 Netflix Ribbon 实现。通过 Spring Cloud 的封装, 可以轻松地将面向服务的 REST 模板请求自动转换成客户端负载均衡的服务调用

Spring Cloud Ribbon 虽然只是一个工具类框架,它不像服务注册中心、配置中心、API 网关那样需要独立部署, 但是它几乎存在于每一个 Spring Cloud 构建的微服务和基础设施中。因为微服务间的调用,API 网关的请求转发等内容实际上都是通过 Ribbon 来实现的。

客户端负载均衡

负载均衡在系统架构中是一个非常重要,并且是不得不去实施的内容。因为负载均衡是对系统的高可用网络压力的缓解处理能力扩容的重要手段之一。

通常所说的负载均衡都指的是服务端负载均衡,其中分为硬件负载均衡软件负载均衡。硬件负载均衡主要通过在服务器节点之间安装专门用于负载均衡的设备,比如 F5 等;而软件负载均衡则是通过在服务器上安装一些具有均衡负载功能或模块的软件来完成请求分发工作,比如 Nginx 等。

硬件负载均衡的设备或者软件负载均衡的软件模块都会维护一个下挂可用的服务端清单,通过心跳检测来剔除故障的服务端节点,以保证清单中都是可以正常访问的服务端节点。当客户端发送请求到负载均衡设备的时候,该设备按某种算法(比如线性轮询按权重负载按流量负载等)从维护的可用服务端清单中取出一台服务端的地址,然后进行转发。

客户端负载均衡和服务端负载均衡最大的不同点在于服务清单所存储的位置。在客户端负载均衡中,所有客户端节点都维护着自己要访问的服务端清单,而这些服务端的清单来自于服务注册中心,如 Eureka 服务端。同服务端负载均衡的架构类似,在客户端负载均衡中也需要心跳去维护服务端清单的健康性,只是这个步骤需要与服务注册中心配合完成。

负载均衡策略

  • 从服务实例清单中随机选择一个服务实例。
  • 按照线性轮询的方式依次选择每个服务实例。
  • 重试机制 + 线性轮询
  • 根据实例的运行情况来计算权重, 并根据权重(与响应时间有关)来挑选实例。
  • 线性轮询负载均衡器中维护的所有服务实例,过滤掉故障的实例,找出并发请求数最小的一个,选出最空闲的实例。
  • 过滤清单,再线性轮询选择。

参考:

《Spring Cloud 微服务实战》翟永超 著

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值