Ribbon负载均衡

负载均衡

服务器端的负载均衡:nginx接收客户端发来的请求,根据负载均衡策略,反向代理到另一台服务器上,nginx是安装在服务器端的,它的负载均衡策略,一般不由发送请求的客户端这一方控制

服务访问列表 在nginx服务器上的,由nginx反向代理+负载均衡去转发

客户端的负载均衡:提前把服务提供方的服务地址(一般有多个)拉取过来,然后根据客户端自己的请求情况做负载均衡,可以由发送请求的这一方自己控制。例子:如nacos中默认使用的Ribbon,nacos中的需要发送请求的一方(也叫客户端)就会设置定时任务,拉取服务访问列表到本地

服务访问列表 在 客户端本地,由客户端 发送定时任务到nacos服务中心 去维护 这张表



负载均衡算法



如何使用ribbon

这里面的每一个类都是一种负载均衡的策略

修改默认负载均衡策略有两种方式

注意:这些操作都是在服务消费方修改的,在客户端修改,因为Ribbon是客户端方的负载均衡策略

方法1. 自定义一个配置类

定义一个配置类 ,再定义一个Bean(方法名一定叫iRule,返回值也一般为IRule,多态的特性)返回上面的某个实现类,就修改成了这个类指定的负载均衡算法

再在启动类上加上注解@RibbonClients指定对那个服务名称生效,这样我们可以针对不同的服务提供方,使用不同负载均衡策略

注意:配置类一定不能 放在启动类 上的注解**@CompentScan**能扫描得到的地方

方法2:配置文件中设置

只需写上 负载均衡 实现的全类名



自定义负载均衡策略

定义一个类,重写AbstractLoadBalancerRule接口中的choose方法即可

方法里前两步,获得了某个服务的所有可用实例,然后 定义一个策略,返回其中一个服务即可

下图中的是随机策略

然后通过配置文件的方式 去使用 即可



Ribbon默认懒加载

Ribbon默认懒加载,意味着只有在发起调用的时候才会创建客户端。如果网络情况不好,第一次调用会超时。



相关推荐
栗豆包2 小时前
w179基于Java Web的流浪宠物管理系统的设计与实现
java·开发语言·spring boot·后端·spring·宠物
伟大的python程序员3 小时前
thinkphp6+swoole使用rabbitMq队列
后端·rabbitmq·swoole
组合缺一3 小时前
无耳科技 Solon v3.0.7 发布(2025农历新年版)
java·后端·科技·solon
天使day4 小时前
SpringCloud两种注册中心
java·spring·spring cloud
蔚一6 小时前
安装最小化的CentOS7后,执行yum命令报错Could not resolve host mirrorlist.centos.org; 未知的错误
java·linux·spring boot·后端·centos·intellij idea
羊小猪~~6 小时前
MYSQL学习笔记(五):单行函数(字符串、数学、日期时间、条件判断、信息、加密、进制转换函数)讲解
数据库·笔记·后端·sql·学习·mysql·考研
羊小猪~~6 小时前
MYSQL学习笔记(六):聚合函数、sql语句执行原理简要分析
java·数据库·c++·后端·sql·mysql·考研
十二同学啊7 小时前
Spring Boot WebMvcConfigurer:定制你的 Web 应用
前端·spring boot·后端
007php00713 小时前
在系统重构中的工作计划与总结
大数据·开发语言·人工智能·后端·重构·aigc·php
计算机-秋大田13 小时前
基于微信的原创音乐小程序的设计与实现(LW+源码+讲解)
java·开发语言·后端·微信·小程序·课程设计