首页 > 其他分享 >SpringCloud入门(四)Ribbon负载均衡

SpringCloud入门(四)Ribbon负载均衡

时间:2024-10-03 23:44:45浏览次数:7  
标签:负载 service SpringCloud IRule 均衡 规则 服务器 Ribbon

一、Ribbon负载均衡原理
SpringCloud底层其实是利用了一个名为Ribbon的组件,来实现负载均衡功能的。

 

 

SpringCloudRibbon的底层采用了一个拦截器,拦截了RestTemplate发出的请求,对地址做了修改。如下图:

 

 

基本流程如下:

- 拦截我们的RestTemplate请求http://userservice/user/1
- RibbonLoadBalancerClient会从请求url中获取服务名称,也就是user-service
- DynamicServerListLoadBalancer根据user-service到eureka拉取服务列表
- eureka返回列表,localhost:8081、localhost:8082
- IRule利用内置负载均衡规则,从列表中选择一个,例如localhost:8081
- RibbonLoadBalancerClient修改请求地址,用localhost:8081替代userservice,得到http://localhost:8081/user/1,发起真实请求

--源码跟踪解析
1.LoadBalancerIntercepor
可以看到这里的intercept方法,拦截了用户的HttpRequest请求,然后做了几件事:

`request.getURI()`:获取请求uri,本例中就是 http://user-service/user/8
`originalUri.getHost()`:获取uri路径的主机名,其实就是服务id,`user-service`
`this.loadBalancer.execute()`:处理服务id,和用户请求。

这里的`this.loadBalancer`是`LoadBalancerClient`类型。

2.LoadBalancerClient

继续跟入execute方法:

代码是这样的:

- getLoadBalancer(serviceId):根据服务id获取ILoadBalancer,而ILoadBalancer会拿着服务id去eureka中获取服务列表并保存起来。
- getServer(loadBalancer):利用内置的负载均衡算法,从服务列表中选择一个。本例中,可以看到获取了8082端口的服务

放行后,再次访问并跟踪,发现获取的是8081:果然实现了负载均衡。
3.负载均衡策略IRule

在刚才的代码中,可以看到获取服务使通过一个`getServer`方法来做负载均衡:


二、Ribbon负载均衡策略

irule接口决定了负载均衡策略,irule接口实现有哪些实现,如何修改实现?


负载均衡策略

负载均衡的规则都定义在IRule接口中,而IRule有很多不同的实现类:如下图:

 

 

不同规则的含义如下:

内置负载均衡规则类 : 规则描述

1.RoundRobinRule : 简单轮询服务列表来选择服务器。它是Ribbon默认的负载均衡规则。
2.AvailabilityFilteringRule : 对以下两种服务器进行忽略: (1)在默认情况下,这台服务器如果3次连接失败,这台服务器就会被设置为“短路”状态。短路状态将持续30秒,如果再次连接失败,短路的持续时间就会几何级地增加。 (2)并发数过高的服务器。如果一个服务器的并发连接数过高,配置了AvailabilityFilteringRule规则的客户端也会将其忽略。并发连接数的上限,可以由客户端的<clientName>.<clientConfigNameSpace>.ActiveConnectionsLimit属性进行配置。
3.WeightedResponseTimeRule : 为每一个服务器赋予一个权重值。服务器响应时间越长,这个服务器的权重就越小。这个规则会随机选择服务器,这个权重值会影响服务器的选择。
4.-- ZoneAvoidanceRule -- : 以区域可用的服务器为基础进行服务器的选择。使用Zone对服务器进行分类,这个Zone可以理解为一个机房、一个机架等。而后再对Zone内的多个服务做轮询。
5.BestAvailableRule : 忽略那些短路的服务器,并选择并发数较低的服务器。
6.RandomRule : 随机选择一个可用的服务器。
7.RetryRule : 重试机制的选择逻辑


默认的实现就是ZoneAvoidanceRule,是一种轮询方案

三、修改负载均衡策略
自定义负载均衡策略:

通过定义IRule实现可以修改负载均衡规则,有两种方式:

1. 代码方式:在order-service中的OrderApplication类中,定义一个新的IRule:(全局配置 )

在order-service中的OrderApplication类中,定义一个新的IRule:

@Bean
public IRule randomRule(){
    return new RandomRule();
}

 

2.配置文件方式:在order-service的application.yml文件中,添加新的配置也可以修改规则:(针对某个微服务配置)

在order-service的application.yml文件中,添加新的配置也可以修改规则:

userservice: # 给某个微服务配置负载均衡规则,这里是userservice服务
  ribbon:
    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule # 负载均衡规则 

 


注意:一般用默认的负载均衡规则,不做修改。

四、懒加载和饥饿加载
Ribbon默认是采用懒加载,即第一次访问时才会去创建LoadBalanceClient,请求时间会很长。

而饥饿加载则会在项目启动时创建,降低第一次访问的耗时,通过下面配置开启饥饿加载:

ribbon:
  eager-load:
    enabled: true
    clients: userservice

 

标签:负载,service,SpringCloud,IRule,均衡,规则,服务器,Ribbon
From: https://www.cnblogs.com/kongsq/p/18446154

相关文章

  • SpringCloud入门(三)Eureka 注册中心
    一、Eureka注册中心简介假如我们的服务提供者user-service部署了多个实例,如图: 问题:-order-service在发起远程调用的时候,该如何得知user-service实例的ip地址和端口?-有多个user-service实例地址,order-service调用时该如何选择?-order-service如何得知某个user-service实例是......
  • 05-LoadBalancer负载均衡
    1.Ribbon目前也进入维护模式1.1Ribbon介绍SpringCloudRibbon是基于NetflixRibbon实现的一套客户端负载均衡的工具。简单的说,Ribbon是Netflix发布的开源项目,主要功能是提供客户端的软件负载均衡算法和服务调用。Ribbon客户端组件提供一系列完善的配置项如连接超时,重试等。简......
  • NAT模式 LVS负载均衡群集部署
    目录NAT模式LVS负载均衡群集部署1.关闭所有虚拟机的防火墙和核心防护2.部署共享存储nfs(ip:192.168.110.20)3.配置nginx节点服务器(192.168.110.70,192.168.110.80)4.配置tomcat节点服务器(192.168.110.50,192.168.110.60)4.配置负载调度器(内网关ens33:192.168.110.10,外网关ens......
  • 负载箱:充电桩测试利器
    RCD负载箱是用于测试和验证电气设备在故障状态下的性能的设备。它可以模拟真实的负载情况,从而帮助工程师和技术人员对设备进行准确的检测和维护。此外,RCD负载箱也是一种重要的安全保护设备,主要用于防止电路中的漏电现象引发的事故。它通常被安装在电路的起始位置,作为主断路器或分......
  • SpringCloud分布式配置中心--出错记录
    报错:问题集中在"${my.content}"占位符无法被解析,注入不识别。结果发现git仓库中的wollo.yml文件的内容格式不对!!!2024-09-3011:31:00.440INFO5660---[main]c.c.c.ConfigServicePropertySourceLocator:Fetchingconfigfromserverat:http://localhost:8888......
  • 返利机器人在电商返利系统中的负载均衡实现
    返利机器人在电商返利系统中的负载均衡实现大家好,我是微赚淘客返利系统3.0的小编,是个冬天不穿秋裤,天冷也要风度的程序猿!今天我们来聊一聊如何在电商返利系统中实现返利机器人的负载均衡,尤其是在面对高并发和大量数据处理场景时,如何通过合理的架构设计确保系统的高可用性与......
  • 【含文档+PPT+源码】基于SpringCloud微服务的船舶交易平台的设计与实现
    项目背景与意义随着全球经济的快速发展,航运业成为国际贸易中不可或缺的一环。船舶交易平台作为航运业的重要组成部分,为船舶买卖、租赁等交易提供了便利和高效的途径。在传统的船舶交易中,买卖双方往往需要通过中介机构来进行交易,这不仅增加了交易的时间和成本,还存在信息不透明......
  • springcloud的gateway处理跨域问题
    gateway处理跨域问题,有两种方式,一种是配置文件,另外一种是代码配置文件spring:cloud:gateway:globalcors:cors-configurations:'[/**]':allowCredentials:trueallowedMethods:"*"allowedHeaders:......
  • springcloud的gateway使用全局过滤器
    全局过滤器是可以做一些统一的事情,比如认证鉴权、日志处理等@ComponentpublicclassLogFilterimplementsGlobalFilter,Ordered{Loggerlog=LoggerFactory.getLogger(this.getClass());@OverridepublicMono<Void>filter(ServerWebExchangeexchange,G......
  • SpringCloud入门
    SpringCloud原版笔记:狂神说笔记——SpringCloud快速入门23-subeiLY-博客园(cnblogs.com)一.前言 常见面试题什么是微服务?微服务之间是如何独立通讯的?SpringCloud和Dubbo有哪些区别?SpringBoot和SpringCloud,请你谈谈对他们的理解什么是服务熔断?什么是服......