SpringCloud Ribbon--负载均衡 原理及应用实例

2023-09-17 17:47:19

😀前言
本篇博文是关于SpringCloud Ribbon的基本介绍,希望你能够喜欢

🏠个人主页:晨犀主页
🧑个人简介:大家好,我是晨犀,希望我的文章可以帮助到大家,您的满意是我的动力😉😉

💕欢迎大家:这里是CSDN,我总结知识的地方,欢迎来到我的博客,感谢大家的观看🥰
如果文章有什么需要改进的地方还请大佬不吝赐教 先在此感谢啦😊

SpringCloud Ribbon

Ribbon 介绍

Ribbon 是什么

  1. Spring Cloud Ribbon 是基于Netflix Ribbon 实现的一套客户端负载均衡的工具。
  2. Ribbon 主要功能是提供客户端负载均衡算法和服务调用
  3. Ribbon 客户端组件提供一系列完善的配置项如连接超时,重试等。
  4. Ribbon 会基于某种规则(如简单轮询,随机连接等)去连接指定服务
  5. 程序员很容易使用Ribbon 的负载均衡算法实现负载均衡
  6. 一句话: Ribbon: 负载均衡+RestTemplate 调用

官网

官网地址:https://github.com/Netflix/ribbon

Ribbon 进入维护状态

  1. 官网地址: https://github.com/Netflix/ribbon

image-20230827142737751

  1. Ribbon 目前进入维护模式, 未来替换方案是Spring Cloud LoadBalancer

LB(Load Balance)

LB 分类
1.集中式LB

即在服务的消费方和提供方之间使用独立的LB设施(可以是硬件,如F5,也可以是软件,如Nginx),由该设施负责把访问请求通过某种策略转发至服务的提供方;LB(Load Balance 负载均衡)

2.进程内LB

将LB逻辑集成到消费方,消费方从服务注册中心获知有哪些服务地址可用,然后再从这些地址中选择出一个合适的服务地址。
Ribbon就属于进程内LB,它只是一个类库,集成于消费方进程,消费方通过它来获取到服务提供方的地址。

实例

-前面member-consumer 轮询负载访问10000/10002 底层就是Ribbon 默认的轮询负载算法

Ribbon 原理

Ribbon 架构图&机制

image-20230827142135956

Ribbon 机制
  1. 先选择EurekaServer,它优先选择在同一个区域内负载较少的server
  2. 再根据用户指定的策略,在从server 取到的服务注册列表中选择一个地址
  3. Ribbon 提供了多种策略∶ 比如轮询、随机和根据响应时间加权。

Ribbon 常见负载算法

image-20230827142234048

替换负载均衡算法-应用实例

需求分析/图解

  1. 需求: 将默认的轮询算法改成随机算法RandomRule
  2. 浏览器输入: http://localhost/member/consumer/get/1
  3. 要求访问的10000/10002 端口的服务是随机的

image-20230827142542177

image-20230827142552806

代码实现

  1. 创建member-service-consumer-80 com/my/springcloud/config/RibbonRule.java
//配置自己的负载均衡算法
@Configuration
public class RibbonRule {
    @Bean
    public IRule myRibbonRule(){
    	return new RandomRule();//随机负载均衡算法
    }
}

2.修改member-service-consumer-80 com/my/springcloud/MemberConsumerApplication.java

@EnableEurekaClient
@SpringBootApplication
@EnableDiscoveryClient //启用服务发现
//使用指定的Ribbon 负载均衡算法规则
@RibbonClient(name = "MEMBER_SERVICE_PROVIDER_URL", configuration = RibbonRule.class)
public class MemberConsumerApplication {
    public static void main(String[] args) {
    	SpringApplication.run(MemberConsumerApplication.class, args);
    }
}

测试

  1. 浏览器输入: http://localhost/member/consumer/get/1
  2. 观察访问的10000/10002 端口的服务是随机的

image-20230827142944021

文章到这里就结束了,如果有什么疑问的地方请指出,诸大佬们一起来评论区一起讨论😁
希望能和诸大佬们一起努力,今后我们一起观看感谢您的阅读🍻
如果帮助到您不妨3连支持一下,创造不易您们的支持是我的动力🤞

更多推荐

Kubernetes中Pod的扩缩容介绍

Kubernetes中Pod的扩缩容介绍在实际生产系统中,我们经常会遇到某个服务需要扩容的场景,也可能会遇到由于资源紧张或者工作负载降低而需要减少服务实例数量的场景。此时可以利用Deployment/RC的Scale机制来完成这些工作。Kubernetes对Pod的扩缩容操作提供了手动和自动两种模式,手动模式通过执行k

零基础学前端(五)模仿QQ官网首页(重点练习HTML+CSS)

1.我前面已经将HTML和CSS讲解完成,希望初学者是跟着一步一步敲代码走过来的。2.我个人觉得先不着急进入Javascript的学习,要将前面写样式,写布局的基础打好,所以我编写了本篇模仿QQ网站首页,请认真阅读。一、确认目标我们要模仿qq官网的首页。你可以点击去看看官网的样子,我将目标图片先贴在下面。素材可以自己通

UWB学习——day4

UWB学习——day4技术劣势技术细节UWB频段系统调制方式UWB帧结构芯片实例技术劣势干扰其它技术,UWB技术目前允许在未授权的3.1GHz至10.6GHz频谱上运行,但该频谱上有许多其它无线通讯所在的频带,容易互相产生干扰,反而限制了适用范围。时钟同步要求高,测距和定位需要高精度的时钟同步频谱利用率低,虽然拥有巨大

实现不同局域网间的文件共享和端口映射,使用Python自带的HTTP服务

文章目录1.前言2.本地文件服务器搭建2.1python的安装和设置2.2cpolar的安装和注册3.本地文件服务器的发布3.1Cpolar云端设置3.2Cpolar本地设置4.公网访问测试5.结语1.前言数据共享作为和连接作为互联网的基础应用,不仅在商业和办公场景有广泛的应用,对于个人用户也有很强的实用意义。也正因如

产业互联网,并非消费互联网式的置身事外

在消费互联网时代,我们听到最多的一个词汇,便是「收割」。当「收割」发展到一定的程度,我们还听到了一个词,叫「豢养」。不得不说,在流量充沛的年代里,通过「收割」和「豢养」的方式,的确是可以获得一定的发展潜能的。然而,等到流量的红利不再,通过简单粗暴的「收割」和「豢养」开始表现出来了越来越多的问题和弊端。我们看到的流量的沉

HEXO 基本使用

1新建、编辑并预览文章1.新建文章hexonew[layout]title#或hexon[layout]title创建文章前要先选定模板,在hexo中也叫做布局。hexo支持三种布局(layout):post(默认)、draft、page。我们先介绍如何使用已有布局,后面还将会介绍如何自定义布局。在博客目录下输入以下命

macOS 中 聚焦搜索 的使用教程

macOS中的聚焦搜索是一个强大的工具,它可以帮助你快速找到文件、应用程序、联系人、电子邮件、互联网搜索结果等。下面是macOS中聚焦搜索的使用教程:1.打开聚焦搜索:使用键盘快捷键:按下键盘上的Command键和空格键(⌘+空格),即可打开聚焦搜索。这是最快的方式。使用鼠标或触控板:点击屏幕右上角的聚焦搜索图标(放大

详细介绍下VLAN隔离与VLAN之间互联

什么VLAN?VLAN代表虚拟局域网(VirtualLocalAreaNetwork),它是一种在物理网络基础上创建逻辑上独立的虚拟网络的技术。VLAN允许将一个局域网划分为多个虚拟的逻辑网络,这些虚拟网络在逻辑上相互隔离,就像它们是物理上分开的一样。通过使用VLAN,可以将不同的设备、用户和资源划分到不同的虚拟网络中

每日练习-8

目录一、选择题二、算法题1.另类加法2、走方格的方案数一、选择题1、解析:当使用new运算符创建一个类的对象数组时,会调用该类的构造函数来初始化每个对象。因此,如果创建了5个对象,那么构造函数会被调用5次。当使用delete运算符删除一个指针时,会调用该指针指向的对象的析构函数来释放内存。但是,如果该指针指向的是一个对

【Spring】IOC基本用法

🎈博客主页:🌈我的主页🌈🎈欢迎点赞👍收藏🌟留言📝欢迎讨论!👏🎈本文由【泠青沼~】原创,首发于CSDN🚩🚩🚩🎈由于博主是在学小白一枚,难免会有错误,有任何问题欢迎评论区留言指出,感激不尽!🌠个人主页目录🌟一、向Spring容器中注册Bean🌟🌟1.1、使用MAVEN注入依赖🌟🌟1.2

华为智慧搜索,下一片流量蓝海的“入海口”

几年前开始,TMT业界就发出了一类质疑的声音:移动互联网的各个APP彼此割裂,是在“孤岛炼油”。大量的应用程序和服务互不打通,形成了严重的数据孤岛,用户只能进行站内搜索,很难穿透APP壁垒,进行全局搜索。《淮南子·氾论训》中写道,“百川异源而皆归于海;百家殊业而皆务于治”。像千百条来自不同源头的江河,最后都会归流入大海

热文推荐