微服务学习:Ribbon实现客户端负载均衡,将请求分发到多个服务提供者

Ribbon是Netflix开源的一个基于HTTP和TCP客户端负载均衡器。它主要用于在微服务架构中实现客户端负载均衡,将请求分发到多个服务提供者上,从而实现高可用性和扩展性。

Ribbon的主要特点包括:

  1. 客户端负载均衡:Ribbon是一个客户端负载均衡器,它将负载均衡算法放到了客户端,而不是像传统的负载均衡器那样放到服务器端。这样可以更灵活地进行负载均衡,并且可以避免单点故障问题。

  2. 多种负载均衡算法:Ribbon支持多种负载均衡算法,如轮询、随机、加权轮询等,可以根据实际需求进行选择。

  3. 与Eureka集成:Ribbon可以与Eureka服务注册中心进行集成,从而自动获取可用的服务实例列表。

  4. 支持自定义:Ribbon提供了丰富的配置项,可以通过配置文件或编程方式来进行自定义,以满足不同的需求。

  5. Spring Cloud集成:Ribbon是Spring Cloud中默认的客户端负载均衡器,可以与其他Spring Cloud组件无缝集成,比如Zuul、Feign等。

通过定义IRule实现可以修改负载均衡规则,有两种方式:

一,代码

application类中

复制代码
@Bean
public IRule randomRule(){
    return new RandomRule();
}

二,配置文件

application.yml中

复制代码
所调用的另一个服务的名称:
  ribbon:
    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.ZoneAvoidanceRule # 轮询负载均衡规则 

注意:bean配置优先级高于yml配置优先级

根据集群负载均衡

复制代码
所调用的另一个服务的名称:
  ribbon:
    NFLoadBalancerRuleClassName: com.alibaba.cloud.nacos.ribbon.NacosRule # 负载均衡规则 

饥饿加载

Ribbon默认是采用懒加载,即第一次访问时才会去创建LoadBalanceClient**,请求时间会很长。**

而饥饿加载则会在项目启动时创建,降低第一次访问的耗时。

复制代码
ribbon:
  eager-load:
    enabled: true # 开启饥饿加载 
    clients: userserver # 指定对userserver这个服务饥饿加载

总结:

1.Ribbon负载均衡规则:

规则接口是****IRule

默认实现是ZoneAvoidanceRule,根据zone选择服务列表,然后轮询

2.负载均衡自定义方式

代码方式:配置灵活,但修改时需要重新打包发布

配置方式:直观,方便,无需重新打包发布,但是无法做全局配置

相关推荐
pengkai火火火1 分钟前
基于springmvc拓展机制的高性能日志审计框架的设计与实现
spring boot·安全·微服务·架构
(●—●)橘子……9 分钟前
记力扣1471.数组中的k个最强值 练习理解
数据结构·python·学习·算法·leetcode
阿蒙Amon12 分钟前
JavaScript学习笔记:17.闭包
javascript·笔记·学习
想不出名字ಥ_ಥ18 分钟前
STM32学习笔记--01学会如何点亮一颗LED灯
笔记·stm32·学习
拾忆,想起28 分钟前
设计模式:软件开发的可复用武功秘籍
开发语言·python·算法·微服务·设计模式·性能优化·服务发现
لا معنى له1 小时前
学习笔记:循环神经网络(RNN)
人工智能·笔记·学习·机器学习
炒毛豆1 小时前
前端可视化-----svg学习笔记
笔记·学习
暗之星瞳1 小时前
PYTHON学习——决策树
python·学习·随机森林
炽烈小老头1 小时前
【 每天学习一点算法 2025/12/17】验证二叉搜索树
学习·算法
Century_Dragon1 小时前
在虚拟工位练真技——汽车塑料件拆装修复软件
学习