微服务学习: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.负载均衡自定义方式

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

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

相关推荐
阿里云云原生4 天前
MSE Nacos Prompt 管理:让 AI Agent 的核心配置真正可治理
微服务·云原生
阿里云云原生4 天前
阿里云微服务引擎 MSE 及 API 网关 2026 年 1 月产品动态
微服务
西岸行者4 天前
学习笔记:SKILLS 能帮助更好的vibe coding
笔记·学习
悠哉悠哉愿意4 天前
【单片机学习笔记】串口、超声波、NE555的同时使用
笔记·单片机·学习
别催小唐敲代码4 天前
嵌入式学习路线
学习
毛小茛4 天前
计算机系统概论——校验码
学习
babe小鑫4 天前
大专经济信息管理专业学习数据分析的必要性
学习·数据挖掘·数据分析
麦聪聊数据4 天前
统一 Web SQL 平台如何收编企业内部的“野生数据看板”?
数据库·sql·低代码·微服务·架构
winfreedoms4 天前
ROS2知识大白话
笔记·学习·ros2
在这habit之下4 天前
Linux Virtual Server(LVS)学习总结
linux·学习·lvs