Ribbon负载均衡

Ribbon负载均衡是一种在分布式系统中用于分发网络请求的技术。它是Netflix开源的负载均衡器,通常与微服务架构一起使用。

微服务架构 中,系统由多个服务实例组成,每个实例运行在不同的主机或容器中。当客户端发送请求时,需要将请求分发到合适的服务实例上进行处理,在保持高可用性和性能的同时避免过载

Ribbon负载均衡通过在客户端端实现负载均衡,将请求分发到可用的服务实例上。它通过以下步骤来选择一个服务实例:

  1. 通过服务注册与发现机制,Ribbon获取可用的服务实例列表。

  2. 根据一定的负载均衡算法,如轮询、随机、加权轮询等,从实例列表中选择一个实例。

  3. 将请求发送到所选的服务实例。

使用Ribbon负载均衡的好处包括:

  • 分发负载:Ribbon能够根据负载均衡算法均匀地将请求分发到不同的服务实例上,避免某个实例过载而影响整个系统的性能。

  • 高可用性:当某个服务实例不可用时,Ribbon能够自动切换到可用的实例,提高系统的可靠性和容错性。

  • 动态更新:当新的服务实例加入或现有的实例退出时,Ribbon能够动态地更新可用的实例列表,确保请求能够正确地分发。

Ribbon负载均衡通常与其他组件一起使用,如服务注册与发现(例如Eureka、Consul)、服务网关(例如Zuul、Spring Cloud Gateway)和断路器(例如Hystrix),以构建弹性和可靠的分布式系统。

Ribbon负载均衡规则

1、规则接口是IRule

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

以上两种策略各有优缺点

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

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

相关推荐
想进大厂的小王3 小时前
项目架构介绍以及Spring cloud、redis、mq 等组件的基本认识
redis·分布式·后端·spring cloud·微服务·架构
customer083 小时前
【开源免费】基于SpringBoot+Vue.JS医院管理系统(JAVA毕业设计)
java·vue.js·spring boot·后端·spring cloud·开源·intellij-idea
杨荧4 小时前
【JAVA毕业设计】基于Vue和SpringBoot的服装商城系统学科竞赛管理系统
java·开发语言·vue.js·spring boot·spring cloud·java-ee·kafka
aloha_78917 小时前
从零记录搭建一个干净的mybatis环境
java·笔记·spring·spring cloud·maven·mybatis·springboot
茶馆大橘19 小时前
微服务系列五:避免雪崩问题的限流、隔离、熔断措施
java·jmeter·spring cloud·微服务·云原生·架构·sentinel
荆州克莱1 天前
[FE] React 初窥门径(四):React 组件的加载过程(render 阶段)
spring boot·spring·spring cloud·css3·技术
Genius Kim1 天前
SpringCloud Sentinel 服务治理详解
spring cloud·sentinel·php
为美好的生活献上中指1 天前
Java学习Day60:微服务总结!(有经处无火,无火处无经)
java·spring boot·spring cloud·微服务·sentinel·jetty