当前位置: 首页 > news >正文

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

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

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

http://www.lryc.cn/news/257788.html

相关文章:

  • 孩子还是有一颗网安梦——Bandit通关教程:Level0
  • 读excel文件,借助openpyxl工具
  • ubuntu16.04升级openssl
  • 【力扣100】56.合并区间
  • 重磅!2023中国高校计算机大赛-人工智能创意赛结果出炉
  • [Linux] 用LNMP网站框架搭建论坛
  • 记录 | 使用samba将ubuntu文件夹映射到windows实现共享文件夹
  • leetcode 股票DP系列 总结篇
  • 深入理解Java虚拟机---对象的创建和内存异常溢出
  • windows MYSQL解决中文乱码问题
  • EasyRecovery2024免费永久版手机数据恢复软件
  • 2023/12/11 作业
  • 【11】Qt Designer
  • 【算法优选】 动态规划之路径问题——贰
  • 从视频中截取指定帧图片
  • 2023最新vue安装(npm,yarn,国内镜像,vue安装,vue导包)全套教程2023年12月最新
  • 性能测试基础
  • 算法与数据结构--最短路径Dijkstra算法
  • ASP.NET Core 8 在 Windows 上各种部署模型的性能测试
  • 跨框架解决方案-Mitosis【Context】
  • 有哪些重要的项目是用 Python 开发的?
  • 【计算机网络】应用层电子邮件协议
  • 视频剪辑:视频转码实用技巧,批量将MP4转为MP3音频
  • 体系化学习运筹学基础算法的实践和总结
  • 【Java探索之旅】我与Java的初相识(一):Java的特性与优点及其发展史
  • 重写 AppiumService 类,添加默认启动参数,并实时显示启动日志
  • [方法论]allocation 空间内容分配
  • 家电制造数字孪生5G智能工厂可视化系统,加速家电制造产业数字化转型
  • Flink入门之部署(二)
  • SQL命令---修改字段名