目录

一、负载均衡概述

二、负载均衡策略

三、懒加载及饥饿加载


一、负载均衡概述

在业务初期,我们一般会先使用单台服务器对外提供服务。随着业务流量越来越大,单台服务器无论如何优化,无论采用多好的硬件,总会有性能天花板,当单服务器的性能无法满足业务需求时,就需要把多台服务器组成集群系统提高整体的处理性能。

基于上述需求,我们要使用统一的流量入口来对外提供服务,本质上就是需要一个流量调度器,通过均衡的算法,将用户大量的请求流量均衡地分发到集群中不同的服务器上。这就是负载均衡

使用负载均衡可以给我们带来的几个好处:

提高了系统的整体性能

提高了系统的扩展性

提高了系统的可用性

LoadBalancerInterceptor负载均衡拦截器

二、负载均衡策略

Ribbon的负载均衡规则是一个叫做IRule的接口来定义的,每一个子接口都是一种规则:

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

简单轮询服务列表来选择服务器。它是Ribbon默认的负载均衡规则

AvailabilityFilteringRule

对以下两种服务器进行忽略:

(1)在默认情况下,这台服务器如果3次连接失败,这台服务器就会被设置为“短路”状态。短路状态将持续30秒,如果再次连接失败,短路的持续时间就会几何级地增加。

(2)并发数过高的服务器。如果一个服务器的并发连接数过高,配置了AvailabilityFilteringRule规则的客户端也会将其忽略。并发连接数的上限,可以由客户端的<clientName>.<clientConfigNameSpace>.ActiveConnectionsLimit属性进行配置

WeightedResponseTimeRule

为每一个服务器赋予一个权重值。服务器响应时间越长,这个服务器的权重就越小。这个规则会随机选择服务器,这个权重值会影响服务器的选择

ZoneAvoidanceRule

以区域可用的服务器为基础进行服务器的选择。使用Zone对服务器进行分类,这个Zone可以理解为一个机房、一个机架等。而后再对Zone内的多个服务做轮询

BestAvailableRule

忽略那些短路的服务器,并选择并发数较低的服务器

RandomRule

随机选择一个可用的服务器

RetryRule

重试机制的选择逻辑

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

1、代码方式:在order-service中的OrderApplication类中,定义一个新的IRule:

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

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

userservice:  ribbon:    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule# 负载均衡规则

三、懒加载及饥饿加载

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

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

ribbon:  eager-load:    enabled: true # 开启饥饿加载    clients: userservice # 指定对userservice这个服务饥饿加载

Ribbon负载均衡策略、懒加载及饥饿加载相关推荐

  1. spring cloud中通过配置文件自定义Ribbon负载均衡策略

    2019独角兽企业重金招聘Python工程师标准>>> spring cloud中通过配置文件自定义Ribbon负载均衡策略 博客分类: 微服务 一.Ribbon中的负载均衡策略 1 ...

  2. 【云原生微服务八】Ribbon负载均衡策略之WeightedResponseTimeRule源码剖析(响应时间加权)

    文章目录 一.前言 二.WeightedResponseTimeRule 1.计算权重? 1)如何更新权重? 2)如何计算权重? 3)例证权重的计算 2.权重的使用 1)权重区间问题? 一.前言 前置 ...

  3. Ribbon负载均衡策略-3

    Ribbon负载均衡策略-3 常用策略 1.RoundRobinRule 轮转调度策略 2.RetryRule重试规律策略 3.RandomRule随机策略 Ribbon的负载均衡策略是由IRule接 ...

  4. SpringCloud组件:Ribbon负载均衡策略及执行原理!

    大家好,我是磊哥. 今天我们来看下微服务中非常重要的一个组件:Ribbon.它作为负载均衡器在分布式网络中扮演着非常重要的角色. 本篇主要内容如下: 在介绍 Ribbon 之前,不得不说下负载均衡这个 ...

  5. Ribbon负载均衡策略配置

    在这里吐槽一句:网上很多文章真是神坑,你不看还好,看了只会问题越来越多,就连之前的问题都没有解决!!! 不多说了,Ribbon作为后端负载均衡器,比Nginx更注重的是请求分发而不是承担并发,可以直接 ...

  6. Ribbon负载均衡策略初步解读

    1.接口实现结构图 此图参考(https://blog.csdn.net/qq_31489805/article/details/80341200) 2.ribbon的几种负载均衡原则 RandomR ...

  7. Ribbon负载均衡策略

    目录 1.基于Ribbon方式的负载均衡,Netflix默认提供了七种负载均衡策略, 2. @LoadBalanced 1.基于Ribbon方式的负载均衡,Netflix默认提供了七种负载均衡策略, ...

  8. ribbon负载均衡策略详解

    一,IRule接口 IRule接口定义了选择负载均衡策略的基本操作.通过调用choose()方法,就可以选择具体的负载均衡策略. // 选择目标服务节点 Server choose(Object va ...

  9. 自定义Ribbon负载均衡策略

    官方文档指出:自定义的负载均衡配置类不能放在 @componentScan 所扫描的当前包下及其子包下,否则我们自定义的这个配置类就会被所有的Ribbon客户端所共享,也就是说我们达不到特殊化定制的目 ...

最新文章

  1. 首次成功实施 XSS 攻击,盗取目标网站大量 VIP 帐号
  2. 一文读懂序列建模(deeplearning.ai)之序列模型与注意力机制
  3. Python 从入门到精通:一个月就够了!
  4. 基于Spring的Web缓存
  5. js日期格式化精髓总结
  6. 项目管理杂感(2)──继续说项目管理的目标
  7. python扫盲系列--(4)
  8. Python TCP服务器
  9. Windows和ubuntu互传文件
  10. keras 中的 verbose 参数详解
  11. (全)Docker安装+人脸比对算法服务(win10)
  12. 崩坏三精准池python模拟
  13. 大腿根部发黑怎么样白,变白方法
  14. 2018人工智能商业价值百强企业出炉 中科博宏赫然在列
  15. 浅析HDMI、DP、雷电接口优缺点
  16. 如何查看本地已连接的wifi密码
  17. Spring和resteasy集成三种方式
  18. 模拟音频处理器:Excite Audio Lifeline Console Mac
  19. 哈希宝-简单上手教程
  20. 蒙特卡洛算法具体是什么

热门文章

  1. 网络--- Nagle算法理解
  2. OMAP3630 Linux I2C总线驱动分析
  3. Echartds-gl (3D) 城市地图,点击事件,实现下钻等操作
  4. 基于WinCE的嵌入式系统注册表的研究(转载)
  5. 汽车小修不求人 应急修车窍门
  6. 2022流动式起重机司机考试模拟100题模拟考试平台操作
  7. 下属工作表现差,评估5个问题
  8. “Wishare杯”南邮第九届大学生程序设计竞赛之网络赛 部分题解
  9. Linux 如何查看.deb文件详细信息版本号包名
  10. 【转】微信之父张小龙谈移动互联网产品:我所说的都是错的!