当前位置: 首页 > article >正文

【微服务】面试 2、负载均衡

在这里插入图片描述

Ribbon 负载均衡流程

在这里插入图片描述

  • Spring Cloud 中负载均衡组件是 Ribbon,在使用 Feign 等组件发起远程调用时,底层会调用 Ribbon 进行负载均衡。
  • 以订单服务(order service)调用用户服务(user service)为例,当 order service 发起远程调用时,会指定 user service 名称,接着调用 Ribbon 组件。Ribbon 从注册中心拉取 user service 的相关信息,获取到如 localhost:8081localhost:8082 等地址后,依据特定策略(如轮询)决定调用哪一台服务器,此过程在客户端(即远程调用发起方)完成。

Ribbon 常见负载均衡策略介绍

  • 轮询(Round Robin):按顺序依次调用服务实例,如有两个实例,先调用 8081,下次则调用 8082,依此类推。
  • 权重选择:依据服务器的响应时间确定权重,响应时间越长权重越小,被选中概率越低。
  • 随机测量:随机挑选一个可用服务器进行调用。
  • 最小连接数(Best Available):忽略短路服务器,选择并发数较低(即空闲较多)的服务器。例如有两台服务器,连接数分别为 100 和 50,会选择连接数为 50 的服务器。
  • 重试机制(Retry):先按轮询方式选择服务进行远程调用,若服务实例不存在或宕机,会按指定时间不断重试获取该服务。
  • 可用性敏感策略:先过滤掉非健康的服务器,再选择连接数较小的服务器进行远程调用。
  • 区域敏感策略:Ribbon 的默认策略。以区域可用服务器为基础进行选择,若存在区域概念(如机房、机架划分),优先选择同一区域内的服务器;若无区域概念,则采用轮询方式。建议在面试中能陈述出轮询、权重、随机、区域敏感这四种常见策略。
    在这里插入图片描述

Ribbon 自定义负载均衡策略实现方法

  • 可创建类实现特定接口(如 IRule 接口),再通过配置类或配置文件进行配置。
  • 配置方式分为全局和局部:
    • 全局配置是在服务发起方添加代码,使所有使用 Ribbon 的远程调用都采用该策略。
    • 局部配置则是在客户端配置文件中指定对某一特定服务调用时使用的负载均衡策略。

在这里插入图片描述

在这里插入图片描述


http://www.kler.cn/a/500559.html

相关文章:

  • Java高频面试之SE-11
  • 依据正则表达式拦截文本
  • 二进制编码 和 Base64编码
  • matlab专栏-模拟滤波器设计
  • Spring——几个常用注解
  • linux服务器安装mysql数据库和nginx
  • 多线程面试相关
  • 【python进阶——封装|继承|多态|类型注解】
  • 【软件安装】Visual Studio Code安装教程VScode安装教程
  • 下载并安装MySQL
  • 基于FFmpeg 6.x与SDL2的音视频播放器开发全解析
  • 数字孪生可视化在各个行业的应用场景
  • 数据结构·二叉树(2)
  • 【RabbitMQ】消息队列消息确认机制
  • 绘制三角形、正六边形、五角星、六角星
  • USRP X310 Windows 烧录镜像
  • 【C++】拷贝构造函数与运算符重载
  • 【Bluedroid】HFP连接流程源码分析(一)
  • 基于ResNet的CIFAR-10分类实现与分析
  • django基于Python的校园个人闲置物品换购平台
  • Android Framework WMS全面概述和知识要点
  • 浅谈云计算03 | 云计算的技术支撑(云使能技术)
  • 基于华为ENSP的OSPF-开放式最短路径优先协议保姆级别详解(1)